Class IndexValueRow
java.lang.Object
org.apache.derby.impl.sql.execute.IndexValueRow
- All Implemented Interfaces:
ExecIndexRow
,ExecRow
,Row
Mapper of ValueRow into ExecIndexRow.
-
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionboolean
areNullsOrdered
(int columnPosition) Return true if orderedNulls was called on this ExecIndexRow for the given column position.cloneColumn
(int columnPosition) Get a clone of a DataValueDescriptor from an ExecRow.void
execRowToExecIndexRow
(ExecRow valueRow) Turn the ExecRow into an ExecIndexRow.getClone()
Clone the Row and its contents.getClone
(FormatableBitSet clonedCols) Clone the Row.getColumn
(int position) Get a DataValueDescriptor in a Row by ordinal position (1-based).Get a new row with the same columns type as this one, containing nulls.void
Get a new DataValueDescriptor[]Get the array form of the row that Access expects.Get a clone of the array form of the row that Access expects.int
nColumns()
void
orderedNulls
(int columnPosition) These two methods are a sort of a hack.void
Reset all columns in the row array to null values.void
setColumn
(int position, DataValueDescriptor col) Set a DataValueDescriptor in a Row by ordinal position (1-based).void
setRowArray
(DataValueDescriptor[] value) Set the array of objectstoString()
-
Field Details
-
valueRow
-
-
Constructor Details
-
IndexValueRow
IndexValueRow(ExecRow valueRow)
-
-
Method Details
-
toString
-
getRowArray
Get the array form of the row that Access expects.- Specified by:
getRowArray
in interfaceExecRow
- See Also:
-
setRowArray
Description copied from interface:ExecRow
Set the array of objects- Specified by:
setRowArray
in interfaceExecRow
- See Also:
-
getRowArrayClone
Get a clone of the array form of the row that Access expects.- Specified by:
getRowArrayClone
in interfaceExecRow
- See Also:
-
nColumns
public int nColumns() -
getColumn
Description copied from interface:Row
Get a DataValueDescriptor in a Row by ordinal position (1-based).- Specified by:
getColumn
in interfaceRow
- Parameters:
position
- The ordinal position of the column.- Returns:
- The DataValueDescriptor, null if no such column exists
- Throws:
StandardException
- Thrown on failure.
-
setColumn
Description copied from interface:Row
Set a DataValueDescriptor in a Row by ordinal position (1-based). -
getClone
Description copied from interface:ExecRow
Clone the Row and its contents. -
getClone
Description copied from interface:ExecRow
Clone the Row. The cloned row will contain clones of the specified columns and the same object as the original row for the other columns. -
getNewNullRow
Description copied from interface:ExecRow
Get a new row with the same columns type as this one, containing nulls.- Specified by:
getNewNullRow
in interfaceExecRow
-
resetRowArray
public void resetRowArray()Reset all columns in the row array to null values.- Specified by:
resetRowArray
in interfaceExecRow
-
cloneColumn
Description copied from interface:ExecRow
Get a clone of a DataValueDescriptor from an ExecRow.- Specified by:
cloneColumn
in interfaceExecRow
- Parameters:
columnPosition
- (1 based)
-
orderedNulls
public void orderedNulls(int columnPosition) Description copied from interface:ExecIndexRow
These two methods are a sort of a hack. The store implements ordered null semantics for start and stop positioning, which is correct for IS NULL and incorrect for everything else. To work around this, TableScanResultSet will check whether the start and stop positions have NULL in any column position other than for an IS NULL check. If so, it won't do the scan (that is, it will return no rows). This method is to inform this ExecIndexRow (which can be used for start and stop positioning) that the given column uses ordered null semantics.- Specified by:
orderedNulls
in interfaceExecIndexRow
- Parameters:
columnPosition
- The position of the column that uses ordered null semantics (zero-based).
-
areNullsOrdered
public boolean areNullsOrdered(int columnPosition) Description copied from interface:ExecIndexRow
Return true if orderedNulls was called on this ExecIndexRow for the given column position.- Specified by:
areNullsOrdered
in interfaceExecIndexRow
- Parameters:
columnPosition
- The position of the column (zero-based) for which we want to check if ordered null semantics are used.- Returns:
- true if we are to use ordered null semantics on the given column
-
execRowToExecIndexRow
Turn the ExecRow into an ExecIndexRow.- Specified by:
execRowToExecIndexRow
in interfaceExecIndexRow
-
getNewObjectArray
public void getNewObjectArray()Description copied from interface:ExecRow
Get a new DataValueDescriptor[]- Specified by:
getNewObjectArray
in interfaceExecRow
-