HBASE-20231 Not able to delete column family from a row using RemoteHTable

Signed-off-by: Ashish Singhi <ashishsinghi@apache.org>
This commit is contained in:
Pankaj Kumar 2018-04-04 10:13:34 +05:30 committed by Ashish Singhi
parent b8a13ba10f
commit a761f175ab
2 changed files with 28 additions and 3 deletions

View File

@ -115,13 +115,16 @@ public class RemoteHTable implements Table {
Iterator ii = quals.iterator(); Iterator ii = quals.iterator();
while (ii.hasNext()) { while (ii.hasNext()) {
sb.append(toURLEncodedBytes((byte[])e.getKey())); sb.append(toURLEncodedBytes((byte[])e.getKey()));
sb.append(':');
Object o = ii.next(); Object o = ii.next();
// Puts use byte[] but Deletes use KeyValue // Puts use byte[] but Deletes use KeyValue
if (o instanceof byte[]) { if (o instanceof byte[]) {
sb.append(':');
sb.append(toURLEncodedBytes((byte[]) o)); sb.append(toURLEncodedBytes((byte[]) o));
} else if (o instanceof KeyValue) { } else if (o instanceof KeyValue) {
if (((KeyValue) o).getQualifierLength() != 0) {
sb.append(':');
sb.append(toURLEncodedBytes(CellUtil.cloneQualifier((KeyValue) o))); sb.append(toURLEncodedBytes(CellUtil.cloneQualifier((KeyValue) o)));
}
} else { } else {
throw new RuntimeException("object type not handled"); throw new RuntimeException("object type not handled");
} }

View File

@ -353,18 +353,27 @@ public class TestRemoteTable {
Put put = new Put(ROW_3); Put put = new Put(ROW_3);
put.addColumn(COLUMN_1, QUALIFIER_1, VALUE_1); put.addColumn(COLUMN_1, QUALIFIER_1, VALUE_1);
put.addColumn(COLUMN_2, QUALIFIER_2, VALUE_2); put.addColumn(COLUMN_2, QUALIFIER_2, VALUE_2);
put.addColumn(COLUMN_3, QUALIFIER_1, VALUE_1);
put.addColumn(COLUMN_3, QUALIFIER_2, VALUE_2);
remoteTable.put(put); remoteTable.put(put);
Get get = new Get(ROW_3); Get get = new Get(ROW_3);
get.addFamily(COLUMN_1); get.addFamily(COLUMN_1);
get.addFamily(COLUMN_2); get.addFamily(COLUMN_2);
get.addFamily(COLUMN_3);
Result result = remoteTable.get(get); Result result = remoteTable.get(get);
byte[] value1 = result.getValue(COLUMN_1, QUALIFIER_1); byte[] value1 = result.getValue(COLUMN_1, QUALIFIER_1);
byte[] value2 = result.getValue(COLUMN_2, QUALIFIER_2); byte[] value2 = result.getValue(COLUMN_2, QUALIFIER_2);
byte[] value3 = result.getValue(COLUMN_3, QUALIFIER_1);
byte[] value4 = result.getValue(COLUMN_3, QUALIFIER_2);
assertNotNull(value1); assertNotNull(value1);
assertTrue(Bytes.equals(VALUE_1, value1)); assertTrue(Bytes.equals(VALUE_1, value1));
assertNotNull(value2); assertNotNull(value2);
assertTrue(Bytes.equals(VALUE_2, value2)); assertTrue(Bytes.equals(VALUE_2, value2));
assertNotNull(value3);
assertTrue(Bytes.equals(VALUE_1, value3));
assertNotNull(value4);
assertTrue(Bytes.equals(VALUE_2, value4));
Delete delete = new Delete(ROW_3); Delete delete = new Delete(ROW_3);
delete.addColumn(COLUMN_2, QUALIFIER_2); delete.addColumn(COLUMN_2, QUALIFIER_2);
@ -394,6 +403,19 @@ public class TestRemoteTable {
assertTrue(Bytes.equals(VALUE_1, value1)); assertTrue(Bytes.equals(VALUE_1, value1));
assertNull(value2); assertNull(value2);
// Delete column family from row
delete = new Delete(ROW_3);
delete.addFamily(COLUMN_3);
remoteTable.delete(delete);
get = new Get(ROW_3);
get.addFamily(COLUMN_3);
result = remoteTable.get(get);
value3 = result.getValue(COLUMN_3, QUALIFIER_1);
value4 = result.getValue(COLUMN_3, QUALIFIER_2);
assertNull(value3);
assertNull(value4);
delete = new Delete(ROW_3); delete = new Delete(ROW_3);
remoteTable.delete(delete); remoteTable.delete(delete);