|
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.Cursor
com.sleepycat.je.SecondaryCursor
public class SecondaryCursor
A database cursor for a secondary database. Cursors are not thread safe and the application is responsible for coordinating any multithreaded access to a single cursor object.
Secondary cursors are returned by SecondaryDatabase.openCursor
and SecondaryDatabase.openSecondaryCursor
. The distinguishing characteristics
of a secondary cursor are:
put()
methods on a secondary cursor
are prohibited.
delete()
method of a secondary cursor will delete the primary
record and as well as all its associated secondary records.
dup(boolean)
will return a SecondaryCursor
.
To obtain a secondary cursor with default attributes:
SecondaryCursor cursor = myDb.openSecondaryCursor(txn, null);
To customize the attributes of a cursor, use a CursorConfig object.
CursorConfig config = new CursorConfig(); config.setReadUncommitted(true); SecondaryCursor cursor = myDb.openSecondaryCursor(txn, config);
Method Summary | |
---|---|
OperationStatus |
delete()
Delete the key/data pair to which the cursor refers from the primary database and all secondary indices. |
SecondaryCursor |
dup(boolean samePosition)
Returns a new SecondaryCursor for the same transaction as
the original cursor. |
SecondaryCursor |
dupSecondary(boolean samePosition)
Deprecated. As of JE 4.0.13, replaced by Cursor.dup(boolean) . |
OperationStatus |
getCurrent(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Returns the key/data pair to which the cursor refers. |
OperationStatus |
getCurrent(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Returns the key/data pair to which the cursor refers. |
OperationStatus |
getFirst(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the first key/data pair of the database, and return that pair. |
OperationStatus |
getFirst(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the first key/data pair of the database, and returns that pair. |
OperationStatus |
getLast(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the last key/data pair of the database, and return that pair. |
OperationStatus |
getLast(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the last key/data pair of the database, and returns that pair. |
OperationStatus |
getNext(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the next key/data pair and return that pair. |
OperationStatus |
getNext(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the next key/data pair and returns that pair. |
OperationStatus |
getNextDup(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
If the next key/data pair of the database is a duplicate data record for the current key/data pair, move the cursor to the next key/data pair of the database and return that pair. |
OperationStatus |
getNextDup(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
If the next key/data pair of the database is a duplicate data record for the current key/data pair, moves the cursor to the next key/data pair of the database and returns that pair. |
OperationStatus |
getNextNoDup(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the next non-duplicate key/data pair and return that pair. |
OperationStatus |
getNextNoDup(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the next non-duplicate key/data pair and returns that pair. |
OperationStatus |
getPrev(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the previous key/data pair and return that pair. |
OperationStatus |
getPrev(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the previous key/data pair and returns that pair. |
OperationStatus |
getPrevDup(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
If the previous key/data pair of the database is a duplicate data record for the current key/data pair, move the cursor to the previous key/data pair of the database and return that pair. |
OperationStatus |
getPrevDup(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
If the previous key/data pair of the database is a duplicate data record for the current key/data pair, moves the cursor to the previous key/data pair of the database and returns that pair. |
OperationStatus |
getPrevNoDup(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the previous non-duplicate key/data pair and return that pair. |
OperationStatus |
getPrevNoDup(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the previous non-duplicate key/data pair and returns that pair. |
Database |
getPrimaryDatabase()
Returns the primary Database
associated with this cursor. |
OperationStatus |
getSearchBoth(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the specified secondary and primary key, where both the primary and secondary key items must match. |
OperationStatus |
getSearchBoth(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
This operation is not allowed with this method signature. |
OperationStatus |
getSearchBothRange(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the specified secondary key and closest matching primary key of the database. |
OperationStatus |
getSearchBothRange(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
This operation is not allowed with this method signature. |
OperationStatus |
getSearchKey(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the given key of the database, and return the datum associated with the given key. |
OperationStatus |
getSearchKey(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the given key of the database, and returns the datum associated with the given key. |
OperationStatus |
getSearchKeyRange(DatabaseEntry key,
DatabaseEntry pKey,
DatabaseEntry data,
LockMode lockMode)
Move the cursor to the closest matching key of the database, and return the data item associated with the matching key. |
OperationStatus |
getSearchKeyRange(DatabaseEntry key,
DatabaseEntry data,
LockMode lockMode)
Moves the cursor to the closest matching key of the database, and returns the data item associated with the matching key. |
OperationStatus |
put(DatabaseEntry key,
DatabaseEntry data)
This operation is not allowed on a secondary database. |
OperationStatus |
putCurrent(DatabaseEntry data)
This operation is not allowed on a secondary database. |
OperationStatus |
putNoDupData(DatabaseEntry key,
DatabaseEntry data)
This operation is not allowed on a secondary database. |
OperationStatus |
putNoOverwrite(DatabaseEntry key,
DatabaseEntry data)
This operation is not allowed on a secondary database. |
Methods inherited from class com.sleepycat.je.Cursor |
---|
close, count, countEstimate, getCacheMode, getConfig, getDatabase, setCacheMode, skipNext, skipPrev |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Method Detail |
---|
public Database getPrimaryDatabase()
Database
associated with this cursor.
Calling this method is the equivalent of the following expression:
((SecondaryDatabase) this.getDatabase()).getPrimaryDatabase()
Database
associated with this cursor.public SecondaryCursor dup(boolean samePosition) throws DatabaseException
SecondaryCursor
for the same transaction as
the original cursor.
dup
in class Cursor
samePosition
- If true, the newly created cursor is initialized
to refer to the same position in the database as the original cursor
(if any) and hold the same locks (if any). If false, or the original
cursor does not hold a database position and locks, the returned
cursor is uninitialized and will behave like a newly created cursor.
DatabasePreemptedException
- in a replicated
environment if the master has truncated, removed or renamed the
database.
OperationFailureException
- if this exception occurred earlier and
caused the transaction to be invalidated.
EnvironmentFailureException
- if an unexpected, internal or
environment-wide failure occurs.
DatabaseException
public SecondaryCursor dupSecondary(boolean samePosition) throws DatabaseException
Cursor.dup(boolean)
.
SecondaryCursor
.
Calling this method is the equivalent of calling dup(boolean)
and
casting the result to SecondaryCursor
.
DatabaseException
dup(boolean)
public OperationStatus delete() throws LockConflictException, DatabaseException, UnsupportedOperationException, IllegalStateException
This method behaves as if Database.delete(com.sleepycat.je.Transaction, com.sleepycat.je.DatabaseEntry)
were called for the
primary database, using the primary key obtained via the secondary key
parameter.
delete
in class Cursor
OperationStatus.KEYEMPTY
if the key/pair at the cursor position has
been deleted; otherwise, OperationStatus.SUCCESS
.
OperationFailureException
- if one of the Write
Operation Failures occurs.
EnvironmentFailureException
- if an unexpected, internal or
environment-wide failure occurs.
UnsupportedOperationException
- if the database is transactional
but this cursor was not opened with a non-null transaction parameter,
or the database is read-only.
IllegalStateException
- if the cursor or database has been closed,
or the cursor is uninitialized (not positioned on a record), or the
non-transactional cursor was created in a different thread.
LockConflictException
DatabaseException
public OperationStatus put(DatabaseEntry key, DatabaseEntry data)
UnsupportedOperationException
will always be thrown by this method.
The corresponding method on the primary database should be used instead.
put
in class Cursor
key
- the key DatabaseEntry
operated on.data
- the data DatabaseEntry
stored.
public OperationStatus putNoOverwrite(DatabaseEntry key, DatabaseEntry data)
UnsupportedOperationException
will always be thrown by this method.
The corresponding method on the primary database should be used instead.
putNoOverwrite
in class Cursor
key
- the key DatabaseEntry
operated on.data
- the data DatabaseEntry
stored.
public OperationStatus putNoDupData(DatabaseEntry key, DatabaseEntry data)
UnsupportedOperationException
will always be thrown by this method.
The corresponding method on the primary database should be used instead.
putNoDupData
in class Cursor
key
- the key DatabaseEntry
operated on.data
- the data DatabaseEntry
stored.
public OperationStatus putCurrent(DatabaseEntry data)
UnsupportedOperationException
will always be thrown by this method.
The corresponding method on the primary database should be used instead.
putCurrent
in class Cursor
data
- - the data DatabaseEntry stored.
A partial data item may be
specified to optimize for partial data update.
OperationStatus.KEYEMPTY
if the key/pair at the cursor position has
been deleted; otherwise, OperationStatus.SUCCESS
.public OperationStatus getCurrent(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getCurrent
in interface ForwardCursor
getCurrent
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.
lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
OperationStatus.KEYEMPTY
if the key/pair at the cursor position has
been deleted; otherwise, OperationStatus.SUCCESS
.
OperationFailureException
- if one of the Read Operation
Failures occurs.
DatabaseException
public OperationStatus getCurrent(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
OperationStatus.KEYEMPTY
if the key/pair at the cursor position has
been deleted; otherwise, OperationStatus.SUCCESS
.
OperationFailureException
- if one of the Read Operation
Failures occurs.
EnvironmentFailureException
- if an unexpected, internal or
environment-wide failure occurs.
IllegalStateException
- if the cursor or database has been closed,
or the cursor is uninitialized (not positioned on a record), or the
non-transactional cursor was created in a different thread.
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 getFirst(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getFirst
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.
lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getFirst(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getLast(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getLast
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.
lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getLast(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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
Cursor
If the cursor is not yet initialized, move the cursor to the first key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the next key/data pair of the database, and that pair is returned. In the presence of duplicate key values, the value of the key may not change.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getNext
in interface ForwardCursor
getNext
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.
lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getNext(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If the cursor is not yet initialized, move the cursor to the first key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the next key/data pair of the database, and that pair is returned. In the presence of duplicate key values, the value of the key may not change.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getNextDup(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getNextDup
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.
lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getNextDup(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the cursor is uninitialized (not positioned on a record), or the
non-transactional cursor was created in a different thread.
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 getNextNoDup(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If the cursor is not yet initialized, move the cursor to the first key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the next non-duplicate key of the database, and that key/data pair is returned.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getNextNoDup
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.
lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getNextNoDup(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If the cursor is not yet initialized, move the cursor to the first key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the next non-duplicate key of the database, and that key/data pair is returned.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getPrev(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If the cursor is not yet initialized, move the cursor to the last key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the previous key/data pair of the database, and that pair is returned. In the presence of duplicate key values, the value of the key may not change.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getPrev
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getPrev(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If the cursor is not yet initialized, move the cursor to the last key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the previous key/data pair of the database, and that pair is returned. In the presence of duplicate key values, the value of the key may not change.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getPrevDup(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getPrevDup
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getPrevDup(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the cursor is uninitialized (not positioned on a record), or the
non-transactional cursor was created in a different thread.
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 getPrevNoDup(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If the cursor is not yet initialized, move the cursor to the last key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the previous non-duplicate key of the database, and that key/data pair is returned.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getPrevNoDup
in class Cursor
key
- the secondary 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getPrevNoDup(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If the cursor is not yet initialized, move the cursor to the last key/data pair of the database, and return that pair. Otherwise, the cursor is moved to the previous non-duplicate key of the database, and that key/data pair is returned.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key returned as output. Its byte array does
not need to be initialized by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getSearchKey(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getSearchKey
in class Cursor
key
- the secondary key used as input. It must be initialized with
a non-null byte array by the caller.data
- the primary data returned as output. Its byte array does
not need to be initialized by the caller.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getSearchKey(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key used as input. It must be initialized with
a non-null byte array by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getSearchKeyRange(DatabaseEntry key, DatabaseEntry data, LockMode lockMode) throws DatabaseException
Cursor
The returned key/data pair is for the smallest key greater than or equal to the specified key (as determined by the key comparison function), permitting partial key matches and range searches.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
getSearchKeyRange
in class Cursor
key
- the secondary key used as input and returned as output. It
must be initialized with a non-null byte array by the caller.data
- the primary data returned as output. Its byte array does
not need to be initialized by the caller.
A partial data item may be
specified to optimize for key only or partial data retrieval.
lockMode
- the locking attributes; if null, default attributes
are used. LockMode.READ_COMMITTED
is not allowed.
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.
DatabaseException
public OperationStatus getSearchKeyRange(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
The returned key/data pair is for the smallest key greater than or equal to the specified key (as determined by the key comparison function), permitting partial key matches and range searches.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key used as input and returned as output. It
must be initialized with a non-null byte array by the caller.pKey
- 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.
A partial data item may be
specified to optimize for key only or partial data retrieval.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getSearchBoth(DatabaseEntry key, DatabaseEntry data, LockMode lockMode)
UnsupportedOperationException
will always be thrown by this method.
The corresponding method with the pKey
parameter should be
used instead.
getSearchBoth
in class Cursor
key
- the key used as input. It must be initialized with a
non-null byte array by the caller.data
- the data used as input. It must be initialized with a
non-null byte array by the caller.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
OperationStatus.NOTFOUND
if no matching key/data pair is found;
otherwise, OperationStatus.SUCCESS
.public OperationStatus getSearchBoth(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key used as input. It must be initialized with
a non-null byte array by the caller.pKey
- the primary key used as input. It must be initialized with
a non-null byte array 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. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 getSearchBothRange(DatabaseEntry key, DatabaseEntry data, LockMode lockMode)
UnsupportedOperationException
will always be thrown by this method.
The corresponding method with the pKey
parameter should be
used instead.
getSearchBothRange
in class Cursor
key
- the key used as input and returned as output. It must be
initialized with a non-null byte array by the caller.data
- the data used as input and returned as output. It must be
initialized with a non-null byte array by the caller.lockMode
- the locking attributes; if null, default attributes are
used. LockMode.READ_COMMITTED
is not allowed.
OperationStatus.NOTFOUND
if no matching key/data pair is found;
otherwise, OperationStatus.SUCCESS
.public OperationStatus getSearchBothRange(DatabaseEntry key, DatabaseEntry pKey, DatabaseEntry data, LockMode lockMode) throws DatabaseException
In the case of any database supporting sorted duplicate sets, the returned key/data pair is for the smallest primary key greater than or equal to the specified primary key (as determined by the key comparison function), permitting partial matches and range searches in duplicate data sets.
If this method fails for any reason, the position of the cursor will be unchanged.
In a replicated environment, an explicit transaction must have been
specified when opening the cursor, unless read-uncommitted isolation is
specified via the CursorConfig
or LockMode
parameter.
key
- the secondary key used as input and returned as output. It
must be initialized with a non-null byte array by the caller.pKey
- the primary key used as input and returned as output. It
must be initialized with a non-null byte array 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. LockMode.READ_COMMITTED
is not allowed.
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.
IllegalStateException
- if the cursor or database has been closed,
or the non-transactional cursor was created in a different thread.
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 |