Class LevelDBKVStore
- All Implemented Interfaces:
CloseableKVStore
,KVStore
,Closeable
,AutoCloseable
- Direct Known Subclasses:
SnapshotLevelDBKVStore
-
Constructor Summary
ConstructorDescriptionLevelDBKVStore
(org.iq80.leveldb.DB db) Convenience constructor.LevelDBKVStore
(org.iq80.leveldb.DB db, org.iq80.leveldb.ReadOptions readOptions, org.iq80.leveldb.WriteBatch writeBatch) Constructor. -
Method Summary
Modifier and TypeMethodDescriptionvoid
close()
Close this instance.protected void
finalize()
Finalize this instance.byte[]
get
(byte[] key) Get the value associated with the given key, if any.org.iq80.leveldb.DB
getDB()
Get theDB
underlying this instance.getRange
(byte[] minKey, byte[] maxKey, boolean reverse) Iterate the key/value pairs in the specified range.void
put
(byte[] key, byte[] value) Set the value associated with the given key.void
remove
(byte[] key) Remove the key/value pair with the given key, if it exists.toString()
Methods inherited from class io.permazen.kv.AbstractKVStore
adjustCounter, decodeCounter, encodeCounter, getAtLeast, getAtMost, removeRange
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, getAtLeast, getAtMost, getRange, getRange, removeRange, removeRange
-
Constructor Details
-
LevelDBKVStore
public LevelDBKVStore(org.iq80.leveldb.DB db) Convenience constructor. Uses default read options and no write batching.- Parameters:
db
- database
-
LevelDBKVStore
public LevelDBKVStore(org.iq80.leveldb.DB db, org.iq80.leveldb.ReadOptions readOptions, org.iq80.leveldb.WriteBatch writeBatch) Constructor.- Parameters:
db
- databasereadOptions
- read options, or null for the defaultwriteBatch
- batch for write operations, or null for none- Throws:
IllegalArgumentException
- ifdb
is null
-
-
Method Details
-
getDB
public org.iq80.leveldb.DB getDB()Get theDB
underlying this instance.- Returns:
- underlying database
-
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
-
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
-
finalize
Finalize this instance. Invokesclose()
to close any unclosed iterators. -
toString
-
close
public void close()Close this instance.This closes any unclosed iterators returned from
getRange()
. This does not close the underlyingDB
or any associatedWriteBatch
.- Specified by:
close
in interfaceAutoCloseable
- Specified by:
close
in interfaceCloseable
- Specified by:
close
in interfaceCloseableKVStore
-