Class XodusKVStore
- All Implemented Interfaces:
CloseableKVStore
,KVStore
,Closeable
,AutoCloseable
-
Constructor Summary
ConstructorDescriptionXodusKVStore
(jetbrains.exodus.env.Environment env, String storeName, boolean keyPrefixing, TransactionType txType) Constructor.XodusKVStore
(jetbrains.exodus.env.Environment env, String storeName, TransactionType txType) Convenience constructor. -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Close this instance, discarding any changes.boolean
close
(boolean commit) Close this instance, optionally comitting any changes.protected void
finalize()
Finalize this instance.byte[]
get
(byte[] key) Get the value associated with the given key, if any.getAtLeast
(byte[] minKey, byte[] maxKey) Get the key/value pair having the smallest key greater than or equal to the given minimum, if any.getAtMost
(byte[] maxKey, byte[] minKey) Get the key/value pair having the largest key strictly less than the given maximum, if any.getRange
(byte[] minKey, byte[] maxKey, boolean reverse) Iterate the key/value pairs in the specified range.jetbrains.exodus.env.Store
getStore()
Get theStore
associated with this instance.jetbrains.exodus.env.Transaction
Get theTransaction
associated with this instance.Get theTransactionType
associated with this instance.boolean
isClosed()
Determine if this instance is closed.void
put
(byte[] key, byte[] value) Set the value associated with the given key.Return a read-only snapshot containing the same data as this instance.void
remove
(byte[] key) Remove the key/value pair with the given key, if it exists.void
removeRange
(byte[] minKey, byte[] maxKey) Remove all key/value pairs whose keys are in a given range.toString()
Methods inherited from class io.permazen.kv.AbstractKVStore
adjustCounter, decodeCounter, encodeCounter
Methods inherited from class java.lang.Object
clone, equals, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface io.permazen.kv.KVStore
adjustCounter, apply, decodeCounter, encodeCounter, getRange, getRange, removeRange
-
Constructor Details
-
XodusKVStore
Convenience constructor.Equivalent to:
SnapshotXodusKVStore(env, storeName, true, txType)
.- Parameters:
env
- Xodus environmentstoreName
- Xodus store nametxType
- transaction type- Throws:
IllegalArgumentException
- ifenv
,storeName
, ortxType
is null
-
XodusKVStore
public XodusKVStore(jetbrains.exodus.env.Environment env, String storeName, boolean keyPrefixing, TransactionType txType) Constructor.The specified
Store
will be created if necessary.- Parameters:
env
- Xodus environmentstoreName
- Xodus store namekeyPrefixing
- if creating a new store, true to create the store with key prefixing (StoreConfig.WITHOUT_DUPLICATES_WITH_PREFIXING
), or false to create the store without key prefixing (StoreConfig.WITHOUT_DUPLICATES
)txType
- transaction type- Throws:
IllegalArgumentException
- ifenv
,storeName
, ortxType
is null
-
-
Method Details
-
getTransactionType
Get theTransactionType
associated with this instance.- Returns:
- associated transaction type
-
getTransaction
public jetbrains.exodus.env.Transaction getTransaction()Get theTransaction
associated with this instance.- Returns:
- associated transaction
-
getStore
public jetbrains.exodus.env.Store getStore()Get theStore
associated with this instance.- Returns:
- associated store
-
isClosed
public boolean isClosed()Determine if this instance is closed.- Returns:
- true if closed, false if still open
-
readOnlySnapshot
Return a read-only snapshot containing the same data as this instance.Though based on the same underlying data, the returned instance and this instance retain no references to each other.
- Returns:
- read-only snapshot
- Throws:
IllegalStateException
- if this instance is closed
-
get
public byte[] get(byte[] key) Description copied from interface:KVStore
Get the value associated with the given key, if any.Modifications to the returned
byte[]
array do not affect this instance.- Specified by:
get
in interfaceKVStore
- Overrides:
get
in classAbstractKVStore
- Parameters:
key
- key- Returns:
- value associated with key, or null if not found
-
getAtLeast
Description copied from interface:KVStore
Get the key/value pair having the smallest key greater than or equal to the given minimum, if any.An optional (exclusive) maximum key may also be specified; if
maxKey
is null, there is no upper bound; ifmaxKey <= minKey
, null is always returned.If keys starting with
0xff
are not supported by this instance, andminKey
starts with0xff
, then this method returns null.Modifications to the returned
byte[]
arrays do not affect this instance.- Specified by:
getAtLeast
in interfaceKVStore
- Overrides:
getAtLeast
in classAbstractKVStore
- Parameters:
minKey
- minimum key (inclusive), or null for no minimum (get the smallest key)maxKey
- maximum key (exclusive), or null for no maximum (no upper bound)- Returns:
- smallest key/value pair with
key >= minKey
andkey < maxKey
, or null if none exists
-
getAtMost
Description copied from interface:KVStore
Get the key/value pair having the largest key strictly less than the given maximum, if any.An optional (inclusive) minimum key may also be specified; if
minKey
is null, there is no lower bound (equivalent to a lower bound of the empty byte array); ifminKey >= maxKey
, null is always returned.If keys starting with
0xff
are not supported by this instance, andmaxKey
starts with0xff
, then this method behaves as ifmaxKey
were null.Modifications to the returned
byte[]
arrays do not affect this instance.- Specified by:
getAtMost
in interfaceKVStore
- Overrides:
getAtMost
in classAbstractKVStore
- Parameters:
maxKey
- maximum key (exclusive), or null for no maximum (get the largest key)minKey
- minimum key (inclusive), or null for no minimum (no lower bound)- Returns:
- largest key/value pair with
key < maxKey
andkey >= minKey
, or null if none exists
-
getRange
Description copied from interface:KVStore
Iterate the key/value pairs in the specified range. The returnedCloseableIterator
'sremove()
method must be supported and should have the same effect as invokingremove()
on the corresponding key.If keys starting with
0xff
are not supported by this instance, andminKey
starts with0xff
, then this method returns an empty iteration.If keys starting with
0xff
are not supported by this instance, andmaxKey
starts with0xff
, then this method behaves as ifmaxKey
were null.The returned
CloseableIterator
is weakly consistent (seejava.util.concurrent
). In short, the returnedCloseableIterator
must not throwConcurrentModificationException
; however, whether or not a "live"CloseableIterator
reflects any modifications made after its creation is implementation dependent. Implementations that do make post-creation updates visible in theCloseableIterator
, even if the update occurs after some delay, must preserve the order in which the modifications actually occurred.The returned
CloseableIterator
itself is not guaranteed to be thread safe; is should only be used in the thread that created it.Invokers of this method are encouraged to
close()
the returned iterators, though this is not required for correct behavior.Modifications to the returned
KVPair
key and valuebyte[]
arrays do not affect this instance.- Specified by:
getRange
in interfaceKVStore
- Parameters:
minKey
- minimum key (inclusive), or null for no minimum (start at the smallest key)maxKey
- maximum key (exclusive), or null for no maximum (end at the largest key)reverse
- true to return key/value pairs in reverse order (i.e., keys descending)- Returns:
- iteration of key/value pairs in the range
minKey
(inclusive) tomaxKey
(exclusive)
-
put
public void put(byte[] key, byte[] value) Description copied from interface:KVStore
Set the value associated with the given key.- Specified by:
put
in interfaceKVStore
- Overrides:
put
in classAbstractKVStore
- Parameters:
key
- keyvalue
- value
-
remove
public void remove(byte[] key) Description copied from interface:KVStore
Remove the key/value pair with the given key, if it exists.- Specified by:
remove
in interfaceKVStore
- Overrides:
remove
in classAbstractKVStore
- Parameters:
key
- key
-
removeRange
public void removeRange(byte[] minKey, byte[] maxKey) Description copied from interface:KVStore
Remove all key/value pairs whose keys are in a given range.The
minKey
must be less than or equal tomaxKey
; if they equal (and not null) then nothing happens; if they are both null then all entries are deleted.If keys starting with
0xff
are not supported by this instance, then:- If
minKey
starts with0xff
, then no change occurs - If
maxKey
starts with0xff
, then this method behaves as ifmaxKey
were null
- Specified by:
removeRange
in interfaceKVStore
- Overrides:
removeRange
in classAbstractKVStore
- Parameters:
minKey
- minimum key (inclusive), or null for no minimummaxKey
- maximum key (exclusive), or null for no maximum
- If
-
finalize
Finalize this instance. Invokesclose()
to close any unclosed iterators. -
toString
-
close
public void close()Close this instance, discarding any changes.This closes the underlying
Transaction
and any unclosed iterators returned fromgetRange()
. This method just invokesclose(false)
.- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceCloseable
- Specified by:
close
in interfaceCloseableKVStore
-
close
public boolean close(boolean commit) Close this instance, optionally comitting any changes.This closes or commits the underlying
Transaction
, and closes any unclosed iterators returned fromgetRange()
. This instance will end up being closed even if commit fails.- Parameters:
commit
- true to commit changes (if any)- Returns:
- true if already closed or successfully closed/commited, false if
commit
is true but the commit fails
-