HBase学习2(HBase shell)

浏览: 1392

HBase 常用命令

查看当前用户:whoami
创建表:create '表名', '列族名1','列族名2','列族名N'
查看所有表:list
描述表: describe ‘表名’
判断表存在: exists '表名'
判断是否禁用启用表:is_enabled '表名'和is_disabled ‘表名’

添加记录: put ‘表名’, ‘rowKey’, ‘列族 : 列‘ , '值'
查看表中的记录总数: count '表名'
查看记录rowkey下的所有数据: get '表名' , 'rowKey'
获取某个列族:get '表名','rowkey','列族'
获取某个列族的某个列:get '表名','rowkey','列族:列’

删除记录:delete ‘表名’ ,‘行名’ , ‘列族:列'

删除整行:deleteall '表名','rowkey'
删除一张表:先要屏蔽该表,才能对该表进行删除
第一步 disable ‘表名’ ,第二步 drop '表名'

清空表:truncate '表名'
查看所有记录:scan "表名"
查看某个表某个列中所有数据: scan "表名" , {COLUMNS=>'列族名:列名'}

进入hbase shell

[root@spark1 ~]# start-hbase.sh #启动hbase
[root@spark1 ~]# hbase shell #
查询当前用户
hbase(main):024:0> whoami
查看有哪些表
hbase(main):020:0> list

表的管理

创建表

语法:create <table>, {NAME => , VERSIONS => <VERSIONS>}
创建表t1,列族为f1,列族版本号为5
hbase(main):001:0> create 't1',{NAME=>'f1',VERSIONS=>5}

创建表t2,有两个family name:f1,f2,且版本数均为2
hbase(main):002:0> create 't2',{NAME => 'f1',VERSIONS => '2'},{NAME => 'f2',VERSINS => 2}

创建表t3
hbase(main):003:0> create 't3','f1','f2','f3'

创建表t4,将表依据分割算法HexStringSplit分布在15个Region里
hbase(main):004:0> create 't4','f1',{NUMREGIONS => 15,SPLITALGO => 'HexStringSplit'}

创建表t5,指定切分点
hbase(main):005:0> create 't5','f1',{SPLITS => ['10','20','30','40']}

创建表users
hbase(main):006:0> create 'users', 'user_id' ,'address','info'
=> Hbase::Table - users

向表t1中行row1,列f1:1,添加数据value1,时间戳为2016121730
hbase(main):007:0> put 't1','key1','f1:1','value1',2016121730

删除表(先屏蔽在删除)

hbase(main):008:0> disable 't1'
hbase(main):009:0> drop 't1'

查看表的结构

hbase(main):010:0> desc 't1'

表数据的增删改查

添加数据

语法:put <table>,<rowkey>,<family:column>,<value>,<timestamp>
给t1表添加条数据
hbase(main):011:0> put 't1','key1','f1:col1','value1'

查询某行记录

查询t1表中key1下所有的值
hbase(main):012:0> get 't1','key1'
查询t1 key1中,f1下1的值
hbase(main):013:0> get 't1','key1','f1:1'
或者
hbase(main):014:0> get 't1','key1',{COLUMN => 'f1:1'}

扫描表(可添加STARTROW、TIMERANGE和FITLER等高级功能)


hbase(main):015:0> scan 't1' ,{LIMIT => 5}

统计表中数据行数

语法:count , {INTERVAL => intervalNum, CACHE => cacheNum}
INTERVAL设置多少行显示一次及对应的rowkey,默认1000;CACHE每次去取的缓存
区大小,默认是10,调整该参数可提高查询速度

查询表t1中的行数,每100条显示一次,缓存区为500
hbase(main):058:0> count 't1',{INTERVAL => 100,CACHE => 500}

删除数据

删除行中某个列值(必须指定列名)

例如:删除表t1,key1中的f1:1的数据
hbase(main):015:0> delete 't1','key1','f1:1'

删除行

hbase(main):016:0> deleteall 't1','key1'

删除表中所有数据

删除t1表中所有数据
hbase(main):017:0> truncate 't1'

权限管理

分配权限

语法 : grant <user> <permissions> <table> <column family> <column
qualifier>

查看权限

语法:user_permission <table>

收回权限

语法:revoke <user> <table> <column family> <column
qualifier>

Region管理

移动region

语法:move 'encodeRegionName', 'ServerName'
encodeRegionName指的regioName后面的编码,ServerName指的是master-stat
us的Region Servers列表

开启/关闭region

语法:balance_switch true|false

其他

查看命令帮助信息
hbase(main):020:0> create help
查看表是否存在
hbase(main):021:0> exists 't1'
推荐 0
本文由 邬家栋 创作,采用 知识共享署名-相同方式共享 3.0 中国大陆许可协议 进行许可。
转载、引用前需联系作者,并署名作者且注明文章出处。
本站文章版权归原作者及原出处所有 。内容为作者个人观点, 并不代表本站赞同其观点和对其真实性负责。本站是一个个人学习交流的平台,并不用于任何商业目的,如果有任何问题,请及时联系我们,我们将根据著作权人的要求,立即更正或者删除有关内容。本站拥有对此声明的最终解释权。

0 个评论

要回复文章请先登录注册