Tips:Hbase shell是基于Ruby实现的,所以shell使用过程可以将HBase命令和Ruby代码混合使用。这就比较高级了,本文只是简单的shell操作,不加入Ruby代码混合使用,感兴趣的小伙伴可以自己去了解学习!!!
1.HBase启动/退出
[root@scnode01 ~]# hbase shell
hbase(main):001:0> exit
2.HBase Help命令
#查看某一组命令下的所有命令的简介和简单示范,如查看ddl组命令的使用示范
hbase(main):001:0> help 'ddl'
#查看查看某个命令的详细使用(help 'shellName')
hbase(main):002:0> help 'alter'
3.HBase general组中的命令
#查看集群状态
hbase(main):003:0> status
#查看集群版本
hbase(main):004:0> version
#查看当前登录用户角色信息
hbase(main):005:0> whoami
#查看对表进行操作的基本命令
hbase(main):006:0> table_help
4.ddl组中的基本命令
4.1 查看所有的表及表属性
#查看所有的表
hbase(main):007:0> list
#查看某表属性desc/describe
hbase(main):007:0> desc 'table'
4.2 creat创建表:create '表名', '列族1', '列族2'...
#创建一个people表,列族为 'p_info','p_work'
hbase(main):009:0> create 'people','p_info','p_work'
#也可以如下方式建表,两者等价
hbase(main):009:0> create 'people',{NAME => 'p_info'},{NAME => 'p_work'}
# 建表同时可以指定表属性信息
hbase(main):009:0> create 'people',{NAME => 'p_info',VERSIONS => 2},{NAME => 'p_work',IN_MEMORY => 'true'}
4.3 alter 修改表
#增加列族 'life'
hbase(main):010:0> alter 'people','life'
#另一种写法
hbase(main):010:0> alter 'people',{NAME => 'life'}
# 修改同时可以设置列族属性
hbase(main):010:0> alter 'people',{NAME => 'life',version => 5}
#删除列族 'life'
hbase(main):011:0> alter 'people',{NAME => 'life',METHOD => 'delete'}
#另一种写法
hbase(main):012:0> alter 'people', 'delete' => 'life'
#增加同时做删除操作
hbase(main):013:0> alter 'people', {NAME => 'hobby'}, {NAME => 'life', METHOD => 'delete'}
#修改列族属性:将people表的life列族版本号改为3
hbase(main):016:0>alter 'people', {NAME => 'life', VERSIONS => 3}
4.4 判断表是否存在 exists 'table_name'
#判断people表是否存在
hbase(main):020:0> exists 'people'
4.5 禁用/启用表
# 禁用表 disable 'table_name'
hbase(main):021:0> disable 'people'
# 查看表是否禁用 is_disabled 'table_name'
hbase(main):022:0> is_disabled 'people'
# 启用表 enable 'table_name'
hbase(main):023:0> enable 'people'
#查看表是否启用 is_enabled 'table_name'
hbase(main):024:0> is_enabled 'people'
4.6 删除表
# hbase的某些版本,在删除表前,需要先禁用表
hbase(main):052:0> disable 'table_name'
hbase(main):053:0> drop 'table_name'
5 dml组中的命令
5.1 插入数据
# put '表名','rowkey','列族名:列名','值'
hbase(main):025:0> put 'people','001','p_info:name', 'XW'
#可以指定时间戳,否则默认为系统当前时间:put '表名','rowkey','列族名:列名','值',时间戳
hbase(main):026:0> put 'people','002','p_info:age',23,1576157464380
5.2 查询某行数据
# 查询某行 get '表名','行键'
hbase(main):029:0> get 'people','001'
# 查询某行,指定列名 get '表名','行键','列族:列'
hbase(main):030:0> get 'people','001','p_info:name'
#查询某行,添加其他限制条件(查询people表中,rowkey为'001'的这一行,只显示p_info:name这一列,且只显示最新的3个版本)
hbase(main):031:0> get 'people', '001', {COLUMNS => 'p_info:name', VERSIONS => 3}
# 查看指定列的内容,并限定显示最新的3个版本和时间范围
hbase(main):032:0> get 'people', '001', {COLUMN => 'p_info:name', VERSIONS => 3, TIMERANGE => [1576157464380, 1576517678420]}
# 查询people表中,rowkey为'001',且某列的内容为'XW'的记录
hbase(main):033:0> get 'people', '001', {FILTER => "ValueFilter(=, 'binary:XW')"}
5.3 全表扫描
# 扫描全表 scan '表名'
hbase(main):034:0> scan 'people'
# 扫描时指定列族
hbase(main):035:0> scan 'people', {COLUMNS => 'p_info'}
#扫描时指定列族,并限定显示最新的3个版本的内容
hbase(main):036:0> scan 'people', {COLUMNS => 'p_info', VERSIONS => 3}
# 设置开启RAW 模式,开启RAW 模式会把那些已添加删除标记但是未实际删除的数据也显示出来
hbase(main):040:0>scan 'people', {COLUMNS => 'p_info', RAW => true}
# 列的过滤:查询people表中列族为p_info和p_work的信息
hbase(main):043:0> scan 'people', {COLUMNS => ['p_info', 'p_work']}
# 查询people表中列族为p_info,列名为name、列族为p_work,列名为job的信息
hbase(main):044:0> scan 'people', {COLUMNS => ['p_info:name', 'p_work:job']}
# 查询people表中列族为p_info,列名为name的信息,并且版本最新的3个
hbase(main):045:0> scan 'people', {COLUMNS => 'p_info:name', VERSIONS => 3}
# 查询people表中列族为p_info和p_work且列名含有a字符的信息
hbase(main):046:0> scan 'people', {COLUMNS => ['p_info', 'p_work'], FILTER => "(QualifierFilter(=,'substring:a'))"}
# 查询people表中列族为p_info,行键范围是[001, 002)的数据
hbase(main):047:0> scan 'people', {COLUMNS => 'p_info', STARTROW => '001', ENDROW => '002'}
# 查询people表中行键以00字符开头的
hbase(main):048:0> scan 'people',{FILTER=>"PrefixFilter('00')"}
# 查询people表中指定时间范围的数据
hbase(main):049:0> scan 'people', {TIMERANGE => [1577181190200, 1577184369212]}
5.4 删除数据 delete '表名','行键','列族:列'
#删除表的001行p_info列族的age列
hbase(main):0:050> delete 'people', '001', 'p_info:age'
5.5 清空表 truncate '表名'
#清空表 people
hbase(main):0:050> truncate 'people'
6 其他命令
#查看命名空间
hbase(main):054:0> list_namespace
NAMESPACE
default # 用户创建的表放在这里
hbase # 系统表空间
# 把表中数据强制写到磁盘 flush '表名'
hbase(main):055:0> flush 'people'