HBase第三天

学习HBase第三天
1.HBase常用shell操作
1.1.进入HBase客户端命令操作界面
bin/hbase shell
在这里插入图片描述
1.2、查看帮助命令
help
1.3、查看当前数据库中有哪些表
list
在这里插入图片描述
1.4、创建一张表
create ‘user’,‘info’,‘data’
或者
create ‘user’, {NAME => ‘info’, VERSIONS => ‘3’},{NAME => ‘data’}

在这里插入图片描述
1.5、添加数据操作
put ‘user’,‘rk001’,‘info:name’,‘zhangsan’
put ‘user’,‘rk001’,‘info:age’,20
put ‘user’,‘rk001’,‘info:gender’,‘female’
put ‘user’,‘rk001’,‘data:name’,‘xiaoli’
put ‘user’,‘rk002’,‘data:name’,‘shagua’
在这里插入图片描述
1.6、查询数据操作
获取user表中row key为rk0001的所有信息
get ‘user’,‘rk001’
在这里插入图片描述
获取user表中row key为rk0001,info列族的所有信息
hbase(main):005:0> get ‘user’,‘rk001’,‘info’
在这里插入图片描述
获取user表中row key为rk0001,info列族的name、age列标示符的信息
hbase(main):006:0> get ‘user’,‘rk001’,‘info:name’,‘info:age’
在这里插入图片描述
获取user表中row key为rk0001,info、data列族的信息
hbase(main):007:0> get ‘user’,‘rk001’,‘info’,‘data’

hbase(main):019:0> get ‘user’, ‘rk0001’, {COLUMN => [‘info’, ‘data’]}
在这里插入图片描述
获取user表中row key为rk0001,cell的值为zhangsan的信息
hbase(main):011:0> get ‘user’,‘rk001’,{FILTER => “ValueFilter(=,‘binary:zhangsan’)”}
FILTER(过滤器) ValueFilter(列值) binary(二进制)
在这里插入图片描述
获取user表中row key为rk0001,列标示符中含有a的信息
hbase(main):013:0> get ‘user’,‘rk001’,{FILTER => “(QualifierFilter(=,‘substring:a’))”}
QualifierFilter(列名) substring(相当于mysql中的like,模糊查询)
在这里插入图片描述
查询user表中的所有信息
hbase(main):014:0> scan ‘user’
查询user表中列族为info的信息
hbase(main):015:0> scan ‘user’,{COLUMNS => ‘info’}
在这里插入图片描述
查询user表中列族为info和data的信息
hbase(main):016:0> scan ‘user’,{COLUMNS => [‘info’,‘data’]}
在这里插入图片描述
查询user表中列族为info、列标示符为name的信息
hbase(main):018:0> scan ‘user’,{COLUMNS=> ‘info:name’}
在这里插入图片描述
查询user表中列族为info、列标示符为name的信息,并且版本最新的5个
hbase(main):022:0> scan ‘user’,{COLUMNS => ‘info:name’,VERSIONS => 5}
在这里插入图片描述
查询user表中列族为info,rk范围是[rk0001, rk0003)的数据
hbase(main):001:0> scan ‘user’, {COLUMNS => ‘info’, STARTROW => ‘rk001’, ENDROW => ‘rk002’}
注:查询的是前闭后开的区间
在这里插入图片描述
查询user表中row key以rk字符开头的
scan ‘user’,{FILTER => “PrefixFilter(‘rk’)”}
在这里插入图片描述
查询user表中指定范围的数据
scan ‘user’, {TIMERANGE => [1392368783980, 1392380169184]}
1.7、更新数据操作
将user表的f1列族版本号改为5
hbase(main):050:0> alter ‘user’, NAME => ‘info’, VERSIONS => 5
1.8、删除数据以及删除表操作
删除user表row key为rk0001,列标示符为info:name的数据
hbase(main):005:0> delete ‘user’,‘rk001’,‘info:name’

删除user表row key为rk0001,列标示符为info:name,timestamp为1392383705316的数据
delete ‘user’, ‘rk0001’, ‘info:name’, 1392383705316

删除一个列族:
alter ‘user’, NAME => ‘info’, METHOD => ‘delete’
或 alter ‘user’, ‘delete’ => ‘info’

清空表数据
hbase(main):017:0> truncate ‘user’

删除表
首先需要先让该表为disable状态,使用命令:
hbase(main):049:0> disable ‘user’
然后才能drop这个表,使用命令:
hbase(main):050:0> drop ‘user’
(注意:如果直接drop表,会报错:Drop the named table. Table must first be disabled)
注:drop、delete、truncate的区别
drop:直接把表删除
delete:直接把表清空,不重置主键
truncate:直接把表清空,重置主键
1.9、统计一张表有多少行数据
hbase(main):053:0> count ‘user’
在这里插入图片描述
2、HBase的高级shell管理命令
2.1、status
例如:显示服务器状态
hbase(main):058:0> status ‘node01’
2.2、whoami
显示HBase当前用户,例如:
hbase> whoami
2.3、list
显示当前所有的表
2.4、count
统计指定表的记录数,例如:
hbase> count ‘user’
2.5、describe
展示表结构信息
2.6、exists
检查表是否存在,适用于表量特别多的情况
2.7、is_enabled、is_disabled
检查表是否启用或禁用
2.8、alter
该命令可以改变表和列族的模式,例如:
为当前表增加列族:
hbase> alter ‘user’, NAME => ‘CF2’, VERSIONS => 2
为当前表删除列族:
hbase(main):002:0> alter ‘user’, ‘delete’ => ‘CF2’
2.9、disable/enable
禁用一张表/启用一张表
2.10、drop
删除一张表,记得在删除表之前必须先禁用
2.11、truncate
禁用表-删除表-创建表

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值