HBase Shell 基本操作

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'
ddl的help(部分截图)
#查看查看某个命令的详细使用(help 'shellName')
hbase(main):002:0> help 'alter'
alter的help(部分截图)
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'}
创建people表
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}
扫描people表
# 设置开启RAW 模式,开启RAW 模式会把那些已添加删除标记但是未实际删除的数据也显示出来
hbase(main):040:0>scan 'people', {COLUMNS => 'p_info', RAW => true}
RAW 模式扫描
# 列的过滤:查询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']}
列过滤2
# 查询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'
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容