oracle.kv.impl.query.runtime.FuncRowVersionIter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of oracle-nosql-server Show documentation
Show all versions of oracle-nosql-server Show documentation
NoSQL Database Server - supplies build and runtime support for the server (store) side of the Oracle NoSQL Database.
/*-
* Copyright (C) 2011, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This file was distributed by Oracle as part of a version of Oracle NoSQL
* Database made available at:
*
* http://www.oracle.com/technetwork/database/database-technologies/nosqldb/downloads/index.html
*
* Please see the LICENSE file included in the top-level directory of the
* appropriate version of Oracle NoSQL Database for a copy of the license and
* additional information.
*/
package oracle.kv.impl.query.runtime;
import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;
import oracle.kv.impl.api.table.FieldDefImpl;
import oracle.kv.impl.api.table.FieldValueImpl;
import oracle.kv.impl.api.table.NullValueImpl;
import oracle.kv.impl.api.table.RowImpl;
import oracle.kv.impl.api.table.TupleValue;
import oracle.kv.impl.query.QueryException;
import oracle.kv.impl.query.compiler.Expr;
import oracle.kv.impl.query.compiler.QueryFormatter;
import oracle.kv.Version;
/**
*
*/
public class FuncRowVersionIter extends PlanIter {
private final PlanIter theInput;
public FuncRowVersionIter(Expr e, int resultReg, PlanIter input) {
super(e, resultReg);
theInput = input;
}
/**
* FastExternalizable constructor.
*/
FuncRowVersionIter(DataInput in, short serialVersion)
throws IOException {
super(in, serialVersion);
theInput = deserializeIter(in, serialVersion);
}
/**
* FastExternalizable writer. Must call superclass method first to
* write common elements.
*/
@Override
public void writeFastExternal(DataOutput out, short serialVersion)
throws IOException {
super.writeFastExternal(out, serialVersion);
serializeIter(theInput, out, serialVersion);
}
@Override
public PlanIterKind getKind() {
return PlanIterKind.FUNC_ROW_VERSION;
}
@Override
public void open(RuntimeControlBlock rcb) {
rcb.setState(theStatePos, new PlanIterState());
theInput.open(rcb);
}
@Override
public boolean next(RuntimeControlBlock rcb) {
PlanIterState state = rcb.getState(theStatePos);
if (state.isDone()) {
return false;
}
boolean more = theInput.next(rcb);
assert(more);
FieldValueImpl row = rcb.getRegVal(theInput.getResultReg());
Version version;
if (row == NullValueImpl.getInstance()) {
rcb.setRegVal(theResultReg, row);
state.done();
return true;
}
if (row.isTuple()) {
version = ((TupleValue)row).getVersion();
} else if (row.isRecord()) {
version = ((RowImpl)row).getVersion();
} else {
throw new QueryException(
"Input to the row_version() function is not a row " +
"variable:\n" + row, getLocation());
}
rcb.setRegVal(theResultReg,
FieldDefImpl.binaryDef.createBinary(version.toByteArray()));
state.done();
return true;
}
@Override
public void reset(RuntimeControlBlock rcb) {
theInput.reset(rcb);
PlanIterState state = rcb.getState(theStatePos);
state.reset(this);
}
@Override
public void close(RuntimeControlBlock rcb) {
PlanIterState state = rcb.getState(theStatePos);
if (state == null) {
return;
}
theInput.close(rcb);
state.close();
}
@Override
protected void displayContent(StringBuilder sb, QueryFormatter formatter) {
theInput.display(sb, formatter);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy