|
Berkeley DB Java Edition version 5.0.34 |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectcom.sleepycat.je.JoinCursor
public class JoinCursor
A specialized join cursor for use in performing equality or natural joins on secondary indices.
A join cursor is returned when calling Database.join
.
To open a join cursor using two secondary cursors:
Transaction txn = ... Database primaryDb = ... SecondaryDatabase secondaryDb1 = ... SecondaryDatabase secondaryDb2 = ...SecondaryCursor cursor1 = null; SecondaryCursor cursor2 = null; JoinCursor joinCursor = null; try { DatabaseEntry key = new DatabaseEntry(); DatabaseEntry data = new DatabaseEntry();
cursor1 = secondaryDb1.openSecondaryCursor(txn, null); cursor2 = secondaryDb2.openSecondaryCursor(txn, null);
key.setData(...); // initialize key for secondary index 1 OperationStatus status1 = cursor1.getSearchKey(key, data, LockMode.DEFAULT); key.setData(...); // initialize key for secondary index 2 OperationStatus status2 = cursor2.getSearchKey(key, data, LockMode.DEFAULT);
if (status1 == OperationStatus.SUCCESS && status2 == OperationStatus.SUCCESS) {
SecondaryCursor[] cursors = {cursor1, cursor2}; joinCursor = primaryDb.join(cursors, null);
while (true) { OperationStatus joinStatus = joinCursor.getNext(key, data, LockMode.DEFAULT); if (joinStatus == OperationStatus.SUCCESS) { // Do something with the key and data. } else { break; } } } } finally { if (cursor1 != null) { cursor1.close(); } if (cursor2 != null) { cursor2.close(); } if (joinCursor != null) { joinCursor.close(); } }
The join algorithm is described here so that its cost can be estimated and compared to other approaches for performing a query. Say that N cursors are provided for the join operation. According to the order they appear in the array the cursors are labeled C(1) through C(n), and the keys at each cursor position are labeled K(1) through K(n).
Cursor.getNextDup
operation on the secondary index. The primary key of a
candidate record is determined in this manner. The primary record itself is
not retrieved and the primary database is not accessed.Cursor.getSearchBoth
operation on the secondary index.
The primary record itself is not retrieved and the primary database is not
accessed.getNext
method. If the getNext(DatabaseEntry,DatabaseEntry,LockMode)
method signature is used,
then the primary database is read to obtain the record data, as if Cursor.getSearchKey
were called for the primary
database. If the getNext(DatabaseEntry,LockMode)
method signature
is used, then only the primary key is returned and the primary database is
not accessed.getNext
method will then return OperationStatus.NOTFOUND
.
Method Summary | |
---|---|
void |
close()
Closes the cursors that have been opened by this join cursor. |
JoinConfig |
getConfig()
Returns this object's configuration. |
Database |
getDatabase()
Returns the primary database handle associated with this cursor. |
OperationStatus |
getNext(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Returns the next primary key and data resulting from the join operation. |
OperationStatus |
getNext(DatabaseEntry key,
LockMode lockMode)
Returns the next primary key resulting from the join operation. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Method Detail |
---|
public void close() throws DatabaseException
The cursors passed to Database.join
are not
closed by this method, and should be closed by the caller.
WARNING: To guard against memory leaks, the application should discard all references to the closed handle. While BDB makes an effort to discard references from closed objects to the allocated memory for an environment, this behavior is not guaranteed. The safe course of action for an application is to discard all references to closed BDB objects.
close
in interface Closeable
EnvironmentFailureException
- if an unexpected, internal or
environment-wide failure occurs.
DatabaseException
public Database getDatabase()
public JoinConfig getConfig()
public OperationStatus getNext(DatabaseEntry key, LockMode lockMode) throws DatabaseException
An entry is returned by the join cursor for each primary key/data
pair having all secondary key values that were specified using the array
of secondary cursors passed to Database.join
.
In a replicated environment, an explicit transaction must have been
specified when opening each cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameters.
key
- the primary key returned as output. Its byte array does not
need to be initialized by the caller.lockMode
- the locking attributes; if null, default attributes
are used.
OperationStatus.NOTFOUND
if no matching key/data pair is found;
otherwise, OperationStatus.SUCCESS
.
OperationFailureException
- if one of the Read Operation
Failures occurs.
EnvironmentFailureException
- if an unexpected, internal or
environment-wide failure occurs.
IllegalArgumentException
- if an invalid parameter is specified,
for example, if a DatabaseEntry parameter is null or does not contain a
required non-null byte array.
DatabaseException
public OperationStatus getNext(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
An entry is returned by the join cursor for each primary key/data
pair having all secondary key values that were specified using the array
of secondary cursors passed to Database.join
.
In a replicated environment, an explicit transaction must have been
specified when opening each cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameters.
key
- the primary key returned as output. Its byte array does not
need to be initialized by the caller.data
- the primary data returned as output. Its byte array does
not need to be initialized by the caller.lockMode
- the locking attributes; if null, default attributes
are used.
OperationStatus.NOTFOUND
if no matching key/data pair is found;
otherwise, OperationStatus.SUCCESS
.
OperationFailureException
- if one of the Read Operation
Failures occurs.
EnvironmentFailureException
- if an unexpected, internal or
environment-wide failure occurs.
IllegalArgumentException
- if an invalid parameter is specified,
for example, if a DatabaseEntry parameter is null or does not contain a
required non-null byte array.
DatabaseException
|
Berkeley DB Java Edition version 5.0.34 |
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |