HBASE 常用的Shell命令汇总

本文汇总了HBase的常用Shell命令,包括进入客户端、查看帮助、表的管理(增删改)、数据的查询与更新以及删除操作。通过这些命令,可以便捷地进行表的创建、数据的读写和维护。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

bin/hbase shell

查看帮助命令

hbase(main):001:0> help

表的增删改

  1. 查看当前数据库中有哪些表
list
  1. 创建一张表
create 'user', 'info', 'data'
说明: user是表名,info是第一个列族的名字,data是第二个列族的名字
或者
create 'user', {NAME => 'info', VERSIONS => '3'}{NAME => 'data'}
  1. 清空表数据
truncate 'user'
  1. 删除表
首先需要先让该表为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’
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值