DbSequence::get |
#include <db_cxx.h>int DbSequence::get(DbTxn *txnid, int32_t delta, db_seq_t *retp, u_int32_t flags);
The DbSequence::get method returns the next available element in the sequence and changes the sequence value by delta. The value of delta must be greater than zero. If there are enough cached values in the sequence handle then they will be returned. Otherwise the next value will be fetched from the database and incremented (decremented) by enough to cover the delta and the next batch of cached values.
If the underlying database handle was opened in a transaction then either the txnid parameter must be a valid transaction handle or DB_AUTO_COMMIT must be specified. The txnid handle must be NULL if the sequence handle was opened with a non-zero cache size.
For maximum concurrency a non-zero cache size should be specified prior to opening the sequence handle and DB_AUTO_COMMIT | DB_TXN_NOSYNC should be specified each DbSequence::get method call.
The DbSequence::get method will return EINVAL if the record in the database is not a valid sequence record, or the sequences have overflowed is range.
Copyright (c) 1996-2004 Sleepycat Software, Inc. - All rights reserved.