2015-01-03 14:52:07 +00:00
|
|
|
// Copyright (c) 2014, Facebook, Inc. All rights reserved.
|
|
|
|
// This source code is licensed under the BSD-style license found in the
|
|
|
|
// LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
// of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
|
|
|
|
package org.rocksdb;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Similar to {@link org.rocksdb.WriteBatch} but with a binary searchable
|
|
|
|
* index built for all the keys inserted.
|
|
|
|
*
|
|
|
|
* Calling put, merge, remove or putLogData calls the same function
|
|
|
|
* as with {@link org.rocksdb.WriteBatch} whilst also building an index.
|
|
|
|
*
|
|
|
|
* A user can call {@link org.rocksdb.WriteBatchWithIndex#newIterator() }to create an iterator
|
|
|
|
* over the write batch or
|
|
|
|
* {@link org.rocksdb.WriteBatchWithIndex#newIteratorWithBase(org.rocksdb.RocksIterator)} to
|
|
|
|
* get an iterator for the database with Read-Your-Own-Writes like capability
|
|
|
|
*/
|
|
|
|
public class WriteBatchWithIndex extends AbstractWriteBatch {
|
|
|
|
/**
|
|
|
|
* Creates a WriteBatchWithIndex where no bytes
|
|
|
|
* are reserved up-front, bytewise comparison is
|
|
|
|
* used for fallback key comparisons,
|
|
|
|
* and duplicate keys operations are retained
|
|
|
|
*/
|
|
|
|
public WriteBatchWithIndex() {
|
|
|
|
super();
|
|
|
|
newWriteBatchWithIndex();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a WriteBatchWithIndex where no bytes
|
|
|
|
* are reserved up-front, bytewise comparison is
|
|
|
|
* used for fallback key comparisons, and duplicate key
|
|
|
|
* assignment is determined by the constructor argument
|
|
|
|
*
|
|
|
|
* @param overwriteKey if true, overwrite the key in the index when
|
2015-01-03 15:23:24 +00:00
|
|
|
* inserting a duplicate key, in this way an iterator will never
|
|
|
|
* show two entries with the same key.
|
2015-01-03 14:52:07 +00:00
|
|
|
*/
|
|
|
|
public WriteBatchWithIndex(boolean overwriteKey) {
|
|
|
|
super();
|
|
|
|
newWriteBatchWithIndex(overwriteKey);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates a WriteBatchWithIndex
|
|
|
|
*
|
|
|
|
* @param fallbackIndexComparator We fallback to this comparator
|
2015-01-03 15:23:24 +00:00
|
|
|
* to compare keys within a column family if we cannot determine
|
|
|
|
* the column family and so look up it's comparator.
|
|
|
|
*
|
|
|
|
* @param reservedBytes reserved bytes in underlying WriteBatch
|
|
|
|
*
|
|
|
|
* @param overwriteKey if true, overwrite the key in the index when
|
|
|
|
* inserting a duplicate key, in this way an iterator will never
|
|
|
|
* show two entries with the same key.
|
2015-01-03 14:52:07 +00:00
|
|
|
*/
|
|
|
|
public WriteBatchWithIndex(AbstractComparator fallbackIndexComparator, int reservedBytes,
|
|
|
|
boolean overwriteKey) {
|
|
|
|
super();
|
|
|
|
newWriteBatchWithIndex(fallbackIndexComparator.nativeHandle_, reservedBytes, overwriteKey);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create an iterator of a column family. User can call
|
|
|
|
* {@link org.rocksdb.RocksIteratorInterface#seek(byte[])} to
|
|
|
|
* search to the next entry of or after a key. Keys will be iterated in the
|
|
|
|
* order given by index_comparator. For multiple updates on the same key,
|
|
|
|
* each update will be returned as a separate entry, in the order of update
|
|
|
|
* time.
|
|
|
|
*
|
|
|
|
* @param columnFamilyHandle The column family to iterate over
|
|
|
|
* @return An iterator for the Write Batch contents, restricted to the column family
|
|
|
|
*/
|
|
|
|
public WBWIRocksIterator newIterator(ColumnFamilyHandle columnFamilyHandle) {
|
|
|
|
return new WBWIRocksIterator(this, iterator1(columnFamilyHandle.nativeHandle_));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create an iterator of the default column family. User can call
|
|
|
|
* {@link org.rocksdb.RocksIteratorInterface#seek(byte[])} to
|
|
|
|
* search to the next entry of or after a key. Keys will be iterated in the
|
|
|
|
* order given by index_comparator. For multiple updates on the same key,
|
|
|
|
* each update will be returned as a separate entry, in the order of update
|
|
|
|
* time.
|
|
|
|
*
|
|
|
|
* @return An iterator for the Write Batch contents
|
|
|
|
*/
|
|
|
|
public WBWIRocksIterator newIterator() {
|
|
|
|
return new WBWIRocksIterator(this, iterator0());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides Read-Your-Own-Writes like functionality by
|
|
|
|
* creating a new Iterator that will use {@link org.rocksdb.WBWIRocksIterator}
|
|
|
|
* as a delta and baseIterator as a base
|
|
|
|
*
|
|
|
|
* @param columnFamilyHandle The column family to iterate over
|
2015-01-03 15:23:24 +00:00
|
|
|
* @param baseIterator The base iterator, e.g. {@link org.rocksdb.RocksDB#newIterator()}
|
2015-01-03 14:52:07 +00:00
|
|
|
* @return An iterator which shows a view comprised of both the database point-in-time
|
|
|
|
* from baseIterator and modifications made in this write batch.
|
|
|
|
*/
|
|
|
|
public RocksIterator newIteratorWithBase(ColumnFamilyHandle columnFamilyHandle,
|
|
|
|
RocksIterator baseIterator) {
|
|
|
|
RocksIterator iterator = new RocksIterator(
|
2015-01-03 15:23:24 +00:00
|
|
|
baseIterator.parent_,
|
2015-01-03 14:52:07 +00:00
|
|
|
iteratorWithBase(columnFamilyHandle.nativeHandle_, baseIterator.nativeHandle_));
|
|
|
|
//when the iterator is deleted it will also delete the baseIterator
|
|
|
|
baseIterator.disOwnNativeHandle();
|
|
|
|
return iterator;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Provides Read-Your-Own-Writes like functionality by
|
|
|
|
* creating a new Iterator that will use {@link org.rocksdb.WBWIRocksIterator}
|
|
|
|
* as a delta and baseIterator as a base. Operates on the default column family.
|
|
|
|
*
|
|
|
|
* @param baseIterator The base iterator, e.g. {@link org.rocksdb.RocksDB#newIterator()}
|
|
|
|
* @return An iterator which shows a view comprised of both the database point-in-time
|
|
|
|
* from baseIterator and modifications made in this write batch.
|
|
|
|
*/
|
|
|
|
public RocksIterator newIteratorWithBase(RocksIterator baseIterator) {
|
2015-01-03 15:23:24 +00:00
|
|
|
return newIteratorWithBase(baseIterator.parent_.getDefaultColumnFamily(), baseIterator);
|
2015-01-03 14:52:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override final native void disposeInternal(long handle);
|
|
|
|
@Override final native int count0();
|
|
|
|
@Override final native void put(byte[] key, int keyLen, byte[] value, int valueLen);
|
|
|
|
@Override final native void put(byte[] key, int keyLen, byte[] value, int valueLen,
|
|
|
|
long cfHandle);
|
|
|
|
@Override final native void merge(byte[] key, int keyLen, byte[] value, int valueLen);
|
|
|
|
@Override final native void merge(byte[] key, int keyLen, byte[] value, int valueLen,
|
|
|
|
long cfHandle);
|
|
|
|
@Override final native void remove(byte[] key, int keyLen);
|
|
|
|
@Override final native void remove(byte[] key, int keyLen, long cfHandle);
|
|
|
|
@Override final native void putLogData(byte[] blob, int blobLen);
|
|
|
|
@Override final native void clear0();
|
|
|
|
|
|
|
|
private native void newWriteBatchWithIndex();
|
|
|
|
private native void newWriteBatchWithIndex(boolean overwriteKey);
|
|
|
|
private native void newWriteBatchWithIndex(long fallbackIndexComparatorHandle, int reservedBytes,
|
|
|
|
boolean overwriteKey);
|
|
|
|
private native long iterator0();
|
|
|
|
private native long iterator1(long cfHandle);
|
|
|
|
private native long iteratorWithBase(long baseIteratorHandle, long cfHandle);
|
|
|
|
}
|