use of com.sleepycat.je.DatabaseEntry in project voldemort by voldemort.
the class BdbRevertPidScanToNewDup method transfer.
@Override
public void transfer() throws Exception {
cursor = srcDB.openCursor(null, null);
DatabaseEntry keyEntry = new DatabaseEntry();
DatabaseEntry valueEntry = new DatabaseEntry();
List<Versioned<byte[]>> vals;
long startTime = System.currentTimeMillis();
int scanCount = 0;
int keyCount = 0;
while (cursor.getNext(keyEntry, valueEntry, LockMode.READ_UNCOMMITTED) == OperationStatus.SUCCESS) {
keyCount++;
vals = StoreBinaryFormat.fromByteArray(valueEntry.getData());
scanCount += vals.size();
// pull out the real key
byte[] stripedKey = StoreBinaryFormat.extractKey(keyEntry.getData());
OperationStatus putStatus = dstDB.put(null, new DatabaseEntry(stripedKey), valueEntry);
if (OperationStatus.SUCCESS != putStatus) {
String errorStr = "Put failed with " + putStatus + " for key" + BdbConvertData.writeAsciiString(keyEntry.getData());
logger.error(errorStr);
throw new Exception(errorStr);
}
if (scanCount % 1000000 == 0)
logger.info("Reverted " + scanCount + " entries in " + (System.currentTimeMillis() - startTime) / 1000 + " secs");
}
logger.info("Reverted " + scanCount + " entries and " + keyCount + " keys in " + (System.currentTimeMillis() - startTime) / 1000 + " secs");
}
use of com.sleepycat.je.DatabaseEntry in project GeoGig by boundlessgeo.
the class BDBJEPointCache method get.
@Override
public CoordinateSequence get(List<Long> ids) {
Preconditions.checkNotNull(ids, "ids is null");
OSMCoordinateSequence cs = CSFAC.create(ids.size());
DatabaseEntry key = new DatabaseEntry();
DatabaseEntry data = new DatabaseEntry();
for (int index = 0; index < ids.size(); index++) {
Long nodeID = ids.get(index);
LongBinding.longToEntry(nodeID.longValue(), key);
OperationStatus status = database.get(null, key, data, LockMode.DEFAULT);
if (!OperationStatus.SUCCESS.equals(status)) {
String msg = String.format("node id %s not found", nodeID);
throw new IllegalArgumentException(msg);
}
int[] c = CoordinateBinding.entryToCoord(data);
cs.setOrdinate(index, 0, c[0]);
cs.setOrdinate(index, 1, c[1]);
}
return cs;
}
use of com.sleepycat.je.DatabaseEntry in project GeoGig by boundlessgeo.
the class JEObjectDatabase method getRawInternal.
@Override
protected InputStream getRawInternal(final ObjectId id, final boolean failIfNotFound) {
checkOpen();
Preconditions.checkNotNull(id, "id");
DatabaseEntry key = new DatabaseEntry(id.getRawValue());
DatabaseEntry data = new DatabaseEntry();
final LockMode lockMode = LockMode.READ_UNCOMMITTED;
Transaction transaction = null;
OperationStatus operationStatus = objectDb.get(transaction, key, data, lockMode);
if (NOTFOUND.equals(operationStatus)) {
if (failIfNotFound) {
throw new IllegalArgumentException("Object does not exist: " + id.toString() + " at " + env.getHome().getAbsolutePath());
}
return null;
}
final byte[] cData = data.getData();
return new ByteArrayInputStream(cData);
}
use of com.sleepycat.je.DatabaseEntry in project GeoGig by boundlessgeo.
the class JEObjectDatabase method putInternal.
private OperationStatus putInternal(final ObjectId id, final byte[] rawData, Transaction transaction) {
OperationStatus status;
final byte[] rawKey = id.getRawValue();
DatabaseEntry key = new DatabaseEntry(rawKey);
DatabaseEntry data = new DatabaseEntry(rawData);
status = objectDb.putNoOverwrite(transaction, key, data);
return status;
}
use of com.sleepycat.je.DatabaseEntry in project GeoGig by boundlessgeo.
the class JEObjectDatabase method exists.
/**
* @see org.locationtech.geogig.storage.ObjectDatabase#exists(org.locationtech.geogig.api.ObjectId)
*/
@Override
public boolean exists(final ObjectId id) {
checkOpen();
Preconditions.checkNotNull(id, "id");
DatabaseEntry key = new DatabaseEntry(id.getRawValue());
DatabaseEntry data = new DatabaseEntry();
// tell db not to retrieve data
data.setPartial(0, 0, true);
final LockMode lockMode = LockMode.READ_UNCOMMITTED;
Transaction transaction = null;
OperationStatus status = objectDb.get(transaction, key, data, lockMode);
return SUCCESS == status;
}
Aggregations