HBASE 常用的Shell命令汇总-大萝卜博客网

进入HBase客户端命令操作界面

bin/hbase shell

查看帮助命令

hbase(main):001:0> help

表的增删改

  • 查看当前数据库中有哪些表
list
  • 创建一张表
create 'user', 'info', 'data'
说明: user是表名,info是第一个列族的名字,data是第二个列族的名字
或者
create 'user', {NAME => 'info', VERSIONS => '3'},{NAME => 'data'}
  • 清空表数据
truncate 'user'
  • 删除表
首先需要先让该表为disable状态,使用命令:
disable 'user'
然后才能drop这个表,使用命令:
drop 'user'

(注意:如果直接drop表,会报错:Drop the named table. Table must first be disabled)

数据操作

  • 通过rowkey进行查询
获取user表中row key为rk0001的所有信息
get 'user','rk001'
  • 查看rowkey下面的某个列族的信息
获取user表中row key为rk0001,info列族的所有信息
get 'user', 'rk0001', 'info'
  • 查看rowkey指定列族指定字段的值
获取user表中row key为rk0001,info列族的name、age列标示符的信息
get 'user', 'rk0001', 'info:name', 'info:age'
  • 查看rowkey指定多个列族的信息
获取user表中row key为rk0001,info、data列族的信息
get 'user', 'rk0001', 'info', 'data'
或者你也可以这样写
get 'user', 'rk0001', {COLUMN => ['info', 'data']}
或者你也可以这样写,也行
get 'user', 'rk0001', {COLUMN => ['info:name', 'data:pic']}
  • 指定rowkey与列值查询
获取user表中row key为rk0001,cell的值为zhangsan的信息
get 'user', 'rk0001', {FILTER => "ValueFilter(=, 'binary:zhangsan')"}
  • 指定rowkey与列值模糊查询
获取user表中row key为rk0001,列标示符中含有a的信息
get 'user', 'rk0001', {FILTER => "(QualifierFilter(=,'substring:a'))"}

继续插入一批数据
put 'user', 'rk0002', 'info:name', 'fanbingbing'
put 'user', 'rk0002', 'info:gender', 'female'
put 'user', 'rk0002', 'info:nationality', '中国'
查询列值为中国的信息
get 'user', 'rk0002', {FILTER => "ValueFilter(=, 'binary:中国')"}

注意 下方的所有查询语句都是scan开头的

  • 查询所有数据
查询user表中的所有信息
scan 'user'

  • 指定列族与列名以及限定版本查询
查询user表中列族为info、列标示符为name的信息,并且版本最新的5个
scan 'user', {COLUMNS => 'info:name', VERSIONS => 5}
  • 指定多个列族与按照数据值模糊查询
查询user表中列族为info和data且列标示符中含有a字符的信息
scan 'user', {COLUMNS => ['info', 'data'], FILTER => "(QualifierFilter(=,'substring:a'))"}

  • rowkey的范围值查询
查询user表中列族为info,rk范围是[rk0001, rk0003)的数据
scan 'user', {COLUMNS => 'info', STARTROW => 'rk0001', ENDROW => 'rk0003'}
  • 指定rowkey模糊查询(只可以查询以什么开头的)
查询user表中row key以rk字符开头的
scan 'user',{FILTER=>"PrefixFilter('rk')"}
  • 指定数据范围值查询
查询user表中指定范围的数据(时间戳)
scan 'user', {TIMERANGE => [1392368783980, 1392380169184]}
  • 更新数据值
    更新操作同插入操作一模一样,只不过有数据就更新,没数据就添加

删除数据以及删除表操作

  • 指定rowkey以及列名进行删除
删除user表row key为rk0001,列标示符为info:name的数据
delete 'user', 'rk0001', 'info:name'
  • 指定rowkey,列名以及字段值进行删除
删除user表row key为rk0001,列标示符为info:name,timestamp为1392383705316的数据
delete 'user', 'rk0001', 'info:name', 1392383705316
  • 删除一个列族
删除一个列族:
alter 'user', NAME => 'info', METHOD => 'delete' 
或 alter 'user', 'delete' => 'info'
  • 清空表数据
truncate 'user'