HBASE-11088 Support Visibility Expression Deletes in Shell (Ram)

This commit is contained in:
Ramkrishna 2014-07-09 11:43:26 +05:30
parent cec30fd8a4
commit eafa9f6c1f
4 changed files with 35 additions and 12 deletions

View File

@ -160,15 +160,32 @@ EOF
#---------------------------------------------------------------------------------------------- #----------------------------------------------------------------------------------------------
# Delete a cell # Delete a cell
def _delete_internal(row, column, timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP) def _delete_internal(row, column,
_deleteall_internal(row, column, timestamp) timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP, args = {})
_deleteall_internal(row, column, timestamp, args)
end end
#---------------------------------------------------------------------------------------------- #----------------------------------------------------------------------------------------------
# Delete a row # Delete a row
def _deleteall_internal(row, column = nil, timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP) def _deleteall_internal(row, column = nil,
timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP, args = {})
raise ArgumentError, "Row Not Found" if _get_internal(row).nil? raise ArgumentError, "Row Not Found" if _get_internal(row).nil?
temptimestamp = timestamp
if temptimestamp.kind_of?(Hash)
timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP
end
d = org.apache.hadoop.hbase.client.Delete.new(row.to_s.to_java_bytes, timestamp) d = org.apache.hadoop.hbase.client.Delete.new(row.to_s.to_java_bytes, timestamp)
if temptimestamp.kind_of?(Hash)
temptimestamp.each do |k, v|
if v.kind_of?(String)
set_cell_visibility(d, v) if v
end
end
end
if args.any?
visibility = args[VISIBILITY]
set_cell_visibility(d, visibility) if visibility
end
if column if column
family, qualifier = parse_column_name(column) family, qualifier = parse_column_name(column)
d.deleteColumns(family, qualifier, timestamp) d.deleteColumns(family, qualifier, timestamp)

View File

@ -30,21 +30,25 @@ marked with the time 'ts1', do:
hbase> delete 'ns1:t1', 'r1', 'c1', ts1 hbase> delete 'ns1:t1', 'r1', 'c1', ts1
hbase> delete 't1', 'r1', 'c1', ts1 hbase> delete 't1', 'r1', 'c1', ts1
hbase> delete 't1', 'r1', 'c1', ts1, {VISIBILITY=>'PRIVATE|SECRET'}
The same command can also be run on a table reference. Suppose you had a reference The same command can also be run on a table reference. Suppose you had a reference
t to table 't1', the corresponding command would be: t to table 't1', the corresponding command would be:
hbase> t.delete 'r1', 'c1', ts1 hbase> t.delete 'r1', 'c1', ts1
hbase> t.delete 'r1', 'c1', ts1, {VISIBILITY=>'PRIVATE|SECRET'}
EOF EOF
end end
def command(table, row, column, timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP) def command(table, row, column,
delete(table(table), row, column, timestamp) timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP, args = {})
delete(table(table), row, column, timestamp, args)
end end
def delete(table, row, column, timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP) def delete(table, row, column,
timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP, args = {})
format_simple_command do format_simple_command do
table._delete_internal(row, column, timestamp) table._delete_internal(row, column, timestamp, args)
end end
end end
end end

View File

@ -29,6 +29,7 @@ a column and timestamp. Examples:
hbase> deleteall 't1', 'r1' hbase> deleteall 't1', 'r1'
hbase> deleteall 't1', 'r1', 'c1' hbase> deleteall 't1', 'r1', 'c1'
hbase> deleteall 't1', 'r1', 'c1', ts1 hbase> deleteall 't1', 'r1', 'c1', ts1
hbase> deleteall 't1', 'r1', 'c1', ts1, {VISIBILITY=>'PRIVATE|SECRET'}
The same commands also can be run on a table reference. Suppose you had a reference The same commands also can be run on a table reference. Suppose you had a reference
t to table 't1', the corresponding command would be: t to table 't1', the corresponding command would be:
@ -36,18 +37,19 @@ t to table 't1', the corresponding command would be:
hbase> t.deleteall 'r1' hbase> t.deleteall 'r1'
hbase> t.deleteall 'r1', 'c1' hbase> t.deleteall 'r1', 'c1'
hbase> t.deleteall 'r1', 'c1', ts1 hbase> t.deleteall 'r1', 'c1', ts1
hbase> t.deleteall 'r1', 'c1', ts1, {VISIBILITY=>'PRIVATE|SECRET'}
EOF EOF
end end
def command(table, row, column = nil, def command(table, row, column = nil,
timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP) timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP, args = {})
deleteall(table(table), row, column, timestamp) deleteall(table(table), row, column, timestamp, args)
end end
def deleteall(table, row, column = nil, def deleteall(table, row, column = nil,
timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP) timestamp = org.apache.hadoop.hbase.HConstants::LATEST_TIMESTAMP, args = {})
format_simple_command do format_simple_command do
table._deleteall_internal(row, column, timestamp) table._deleteall_internal(row, column, timestamp, args)
end end
end end
end end

View File

@ -31,7 +31,7 @@ at row 'r1' under column 'c1' marked with the time 'ts1', do:
hbase> put 't1', 'r1', 'c1', 'value', ts1 hbase> put 't1', 'r1', 'c1', 'value', ts1
hbase> put 't1', 'r1', 'c1', 'value', {ATTRIBUTES=>{'mykey'=>'myvalue'}} hbase> put 't1', 'r1', 'c1', 'value', {ATTRIBUTES=>{'mykey'=>'myvalue'}}
hbase> put 't1', 'r1', 'c1', 'value', ts1, {ATTRIBUTES=>{'mykey'=>'myvalue'}} hbase> put 't1', 'r1', 'c1', 'value', ts1, {ATTRIBUTES=>{'mykey'=>'myvalue'}}
hbase> put 't1', 'r1', 'c1', 'value', ts1, {VISIBILITY=>'PRIVATE|SECRET'}} hbase> put 't1', 'r1', 'c1', 'value', ts1, {VISIBILITY=>'PRIVATE|SECRET'}
The same commands also can be run on a table reference. Suppose you had a reference The same commands also can be run on a table reference. Suppose you had a reference
t to table 't1', the corresponding command would be: t to table 't1', the corresponding command would be: