Ho le seguenti righe con queste chiavi in tabella HBase "MyTable"Come eliminare in massa più righe in hbase?
user_1
user_2
user_3
...
user_9999999
voglio usare la shell HBase per eliminare le righe da:
user_500 di user_900
So che c'è nessun modo per cancellare, ma c'è un modo in cui potrei usare "BulkDeleteProcessor" per fare questo?
vedo qui:
voglio solo incollare nelle importazioni e quindi incollare questo nella shell, ma non hanno idea di come fare per questo. Qualcuno sa come posso usare questo endpoint dalla shell di hbase jruby?
Table ht = TEST_UTIL.getConnection().getTable("my_table");
long noOfDeletedRows = 0L;
Batch.Call<BulkDeleteService, BulkDeleteResponse> callable =
new Batch.Call<BulkDeleteService, BulkDeleteResponse>() {
ServerRpcController controller = new ServerRpcController();
BlockingRpcCallback<BulkDeleteResponse> rpcCallback =
new BlockingRpcCallback<BulkDeleteResponse>();
public BulkDeleteResponse call(BulkDeleteService service) throws IOException {
Builder builder = BulkDeleteRequest.newBuilder();
builder.setScan(ProtobufUtil.toScan(scan));
builder.setDeleteType(deleteType);
builder.setRowBatchSize(rowBatchSize);
if (timeStamp != null) {
builder.setTimestamp(timeStamp);
}
service.delete(controller, builder.build(), rpcCallback);
return rpcCallback.get();
}
};
Map<byte[], BulkDeleteResponse> result = ht.coprocessorService(BulkDeleteService.class, scan
.getStartRow(), scan.getStopRow(), callable);
for (BulkDeleteResponse response : result.values()) {
noOfDeletedRows += response.getRowsDeleted();
}
ht.close();
Se esiste alcun modo per fare questo attraverso JRuby, Java o modo alternativo per eliminare rapidamente più righe va bene.
Solo curioso, com'è quel rubino, come contrassegnato? – lcguida
Flag rimosso, è più jruby. – Rolando