com.caucho.db.sql.IdentityIndexExpr Maven / Gradle / Ivy
/*
* Copyright (c) 1998-2018 Caucho Technology -- all rights reserved
*
* This file is part of Resin(R) Open Source
*
* Each copy or derived work must preserve the copyright notice and this
* notice unmodified.
*
* Resin Open Source is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* Resin Open Source is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE, or any warranty
* of NON-INFRINGEMENT. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License
* along with Resin Open Source; if not, write to the
* Free SoftwareFoundation, Inc.
* 59 Temple Place, Suite 330
* Boston, MA 02111-1307 USA
*
* @author Scott Ferguson
*/
package com.caucho.db.sql;
import java.io.IOException;
import java.sql.SQLException;
import com.caucho.db.table.TableIterator;
class IdentityIndexExpr extends RowIterateExpr {
private IdExpr _columnExpr;
private Expr _expr;
IdentityIndexExpr(IdExpr index, Expr expr)
{
_expr = expr;
_columnExpr = index;
if (expr == null || index == null)
throw new NullPointerException();
index.getColumn();
}
/**
* Binds the expression.
*/
@Override
public Expr bind(Query query)
throws SQLException
{
_expr = _expr.bind(query);
return this;
}
/**
* Returns true if shifting the child rows will make a difference.
*/
@Override
boolean allowChildRowShift(QueryContext context, TableIterator rowIter)
{
return false;
}
/**
* Sets the initial row.
*/
@Override
boolean init(QueryContext context, TableIterator rowIter)
throws SQLException, IOException
{
rowIter.init(context);
// the Query will call initRow immediately after, so the following
// call isn't necessary
//return initRow(context, rowIter);
return true;
}
/**
* Sets the initial row.
*/
@Override
boolean initRow(QueryContext context, TableIterator tableIter)
throws SQLException, IOException
{
long rowAddr = evalIndex(context);
if (rowAddr == 0)
return false;
//context.unlock();
if (! tableIter.isValidRow(rowAddr)) {
return false;
}
tableIter.setRow(rowAddr);
//context.lock();
return true;
}
/**
* Returns the next row.
*/
@Override
boolean nextRow(QueryContext context, TableIterator table)
{
return false;
}
long evalIndex(QueryContext context)
throws SQLException
{
long value = _expr.evalLong(context);
if (value <= 0) {
//System.out.println("EVAL: " + length);
return 0;
}
return value;
}
/**
* Returns the next row.
*/
@Override
boolean nextBlock(QueryContext context, TableIterator rowIter)
throws IOException, SQLException
{
context.unlock();
return false;
}
@Override
public String toString()
{
return "(" + _columnExpr + " = " + _expr + ")";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy