HBase Shell整理

常用命令

# 服务器的细节和系统的状态
status
#HBase系统使用的版本
version
# 帮助
table_help
# 当前HBase用户
whoami

表操作

# 列出表
list
# 创建表student, 为表建列族info、classes
# create 表名,列族名1,列族名2,......
create 'student','info','classes'
# 查看表结构
# describe 表名
describe 'student'
# 修改表结构
# 列家族classes单元的最大版本数目设置为5
alter 'student', NAME => 'classes', VERSIONS => 5
# 添加列族
alter 'student', 'score'
# 删除列族
alter 'student', 'delete'=>'address'
# 启用表
enable 'student'
# 表是否存在
exists 'student'
# 禁用表
disable 'student'
# 批量禁用表
disable_all 'stu.*' # 正则表达式
# 查看表是否被禁用
is_disabled 'student'
# 删除表(注意,只能删除被禁用的表)
delete 'student'
# 批量删除表
delete_all 'stu.*' # 正则表达式

数据增、删、改

# 插入/更新数据
# put 表名,rowkey,列族名:列名,值
put 'student','stu1|ts1','info:name','张三'
# 删除某列数据
delete 'student','stu1|ts1','classes:name'
# 删除某行数据
deleteall 'student','stu1|ts1'

统计表行数

count 'student'

数据查询,根据rowkey获取单条数据

# 单条数据读取一行
get 'student','stu1|ts1'
# 单条数据读取指定列
get 'student','stu1|ts1',{COLUMN=>'info:name'}

数据扫描,根据条件获取数据集

# 获取表中所有数据
scan 'student'
# 哪一列值=李四(跨列族)
# put 'student','stu1','info:name','李四'
# put 'student','stu2','classes:name','李四'
scan 'student', FILTER=>"ValueFilter(=,'binary:李四')"
# 哪一列值包含class(跨列族)
# put 'student','stu4','info:name','class2'
# put 'student','stu4','classes:name','class1'
# put 'student','stu4','info:address','beijing class3'
scan 'student', FILTER=>"ValueFilter(=,'substring:class')"
# 列名为name且值中包含class(跨列族)
scan 'student', FILTER=>"ColumnPrefixFilter('name') AND ValueFilter(=,'substring:class')"
# 列名为name且值等于class1或值中包含class2(跨列族)
scan 'student', FILTER=>"ColumnPrefixFilter('name') AND (ValueFilter(=,'binary:class1') OR ValueFilter(=,'substring:class2'))"
# rowKey以s开头
scan 'student',FILTER => "PrefixFilter ('s')"
# FirstKeyOnlyFilter: 一个rowkey可以有多个version,同一个rowkey的同一个column也会有多个的值, 只拿出key中的第一个column的第一个version
# KeyOnlyFilter: 只要key,不要value
scan 'student', FILTER=>"FirstKeyOnlyFilter() AND ValueFilter(=,'binary:class1') AND KeyOnlyFilter()"
# 从stu1开始,找到所有的rowkey以stu开头的
scan 'student', {STARTROW=>'stu1', FILTER => "PrefixFilter ('stu')"}
# rowkey从stu1开始,到stu3结束的所有数据,不包含stu3
scan 'student', {STARTROW=>'stu1', STOPROW=>'stu3'}
# 查询rowkey里面包含stu的
import org.apache.hadoop.hbase.filter.CompareFilter
import org.apache.hadoop.hbase.filter.SubstringComparator
import org.apache.hadoop.hbase.filter.RowFilter
scan 'student', {FILTER => RowFilter.new(CompareFilter::CompareOp.valueOf('EQUAL'), SubstringComparator.new('stu'))}
# 查询rowkey里面以st开头的,[使用正则表达式]
scan 'student', {FILTER => RowFilter.new(CompareFilter::CompareOp.valueOf('EQUAL'),RegexStringComparator.new('^st.*'))}
# nam开头的列中并且值为class1的:
scan 'student', FILTER=>"ColumnPrefixFilter('nam') AND ValueFilter(=,'binary:class1')"
# SingleColumnValueFilter的使用,name开头的列中并且值为class1的
import org.apache.hadoop.hbase.filter.CompareFilter
import org.apache.hadoop.hbase.filter.SingleColumnValueFilter
import org.apache.hadoop.hbase.filter.SubstringComparator
scan 'student', {COLUMNS => 'info:name', FILTER => SingleColumnValueFilter.new(Bytes.toBytes('info'), Bytes.toBytes('name'), CompareFilter::CompareOp.valueOf('EQUAL'), Bytes.toBytes('class1'))}

参考博文:
https://blog.csdn.net/liuxiao723846/article/details/73823056

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值