oracle.kv.impl.api.ops.MultiTableOperation 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.api.ops;
import static oracle.kv.impl.api.ops.InternalOperationHandler.MIN_READ;
import static oracle.kv.impl.util.ObjectUtil.checkNull;
import static oracle.kv.impl.util.SerialVersion.EMPTY_READ_FACTOR_VERSION;
import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException;
import oracle.kv.Depth;
import oracle.kv.KeyRange;
import oracle.kv.impl.api.table.TargetTables;
/**
* This is an intermediate class that encapsulates a get or iteration
* operation on multiple tables. It can be directly constructed by
* server-side iteration code, but is usually used in the context of
* a table iteration client request.
*
* @see #writeFastExternal FastExternalizable format
*/
public abstract class MultiTableOperation extends MultiKeyOperation {
/*
* Encapsulates the target table, child tables, ancestor tables.
*/
private final TargetTables targetTables;
private final int emptyReadFactor;
/**
* Construct a multi-get operation.
*/
public MultiTableOperation(OpCode opCode,
byte[] parentKey,
TargetTables targetTables,
KeyRange subRange) {
this(opCode, parentKey, targetTables, subRange, 1 /* emptyReadFactor */);
}
public MultiTableOperation(OpCode opCode,
byte[] parentKey,
TargetTables targetTables,
KeyRange subRange,
int emptyReadFactor) {
super(opCode, parentKey, subRange, Depth.PARENT_AND_DESCENDANTS);
checkNull("targetTables", targetTables);
this.targetTables = targetTables;
/* emptyReadFactor is serialized as a byte */
assert emptyReadFactor <= Byte.MAX_VALUE;
this.emptyReadFactor = emptyReadFactor;
}
/**
* FastExternalizable constructor. Must call superclass constructor first
* to read common elements.
*/
MultiTableOperation(OpCode opCode, DataInput in, short serialVersion)
throws IOException {
super(opCode, in, serialVersion);
targetTables = new TargetTables(in, serialVersion);
if (serialVersion >= EMPTY_READ_FACTOR_VERSION) {
emptyReadFactor = in.readByte();
} else {
emptyReadFactor = 1;
}
}
TargetTables getTargetTables() {
return targetTables;
}
/**
* Writes this object to the output stream. Format:
*
* - ({@link MultiKeyOperation}) {@code super}
*
- ({@link TargetTables}) {@link #getTargetTables targetTables}
*
*/
@Override
public void writeFastExternal(DataOutput out, short serialVersion)
throws IOException {
super.writeFastExternal(out, serialVersion);
targetTables.writeFastExternal(out, serialVersion);
if (serialVersion >= EMPTY_READ_FACTOR_VERSION) {
out.writeByte(emptyReadFactor);
}
}
@Override
public long getTableId() {
return targetTables.getTargetTableId();
}
@Override
public void addEmptyReadCharge() {
/*
* Override to factor in the emptyReadFactor, only count the empty
* read if current readKB is 0
*/
if (getReadKB() == 0) {
addReadBytes(emptyReadFactor * MIN_READ);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy