HBase(3):HBase Shell 操作
目录
0. 相关文章链接
1. 基本操作
1) 进入 HBase 客户端命令行
bin/hbase shell
2) 查看帮助命令
能够展示 HBase 中所有能使用的命令:
主要使用的命令有 namespace 命令空间相关
DDL 创建修改表格
DML 写入读取数据
-- 执行命令如下:
hbase:001:0> help
2. namespace
1) 创建命名空间
使用特定的 help 语法能够查看命令如何使用
help 'create_namespace'
2) 创建命名空间 bigdata
create_namespace 'bigdata'
3) 查看所有的命名空间
list_namespace
3. DDL
3.1. 创建表
在 bigdata 命名空间中创建表格 student,两个列族。info 列族数据维护的版本数为 5 个,如果不写默认版本数为 1。
create 'bigdata:student', {NAME => 'info', VERSIONS =>5}, {NAME => 'msg'}
如果创建表格只有一个列族,没有列族属性,可以简写;如果不写命名空间,使用默认的命名空间 default。
create 'student1','info'
3.2. 查看表
查看表有两个命令: list 和 describe
-- list:查看所有的表名
list
-- describe:查看一个表的详情
describe 'student1'
3.3. 修改表
表名创建时写的所有和列族相关的信息,都可以后续通过 alter 修改,包括增加删除列族。
1) 增加列族和修改信息都使用覆盖的方法
alter 'student1', {NAME => 'f1', VERSIONS => 3}
2) 删除信息使用特殊的语法
alter 'student1', NAME => 'f1', METHOD => 'delete'
alter 'student1', 'delete' => 'f1'
3.4. 删除表
shell 中删除表格,需要先将表格状态设置为不可用
disable 'student1'
drop 'student1'
4. DML
4.1. 写入数据
在 HBase 中如果想要写入数据,只能添加结构中最底层的 cell。可以手动写入时间戳指定 cell 的版本,推荐不写默认使用当前的系统时间。
put 'bigdata:student','1001','info:name','zhangsan'
put 'bigdata:student','1001','info:name','lisi'
put 'bigdata:student','1001','info:age','18'
如果重复写入相同 rowKey,相同列的数据,会写入多个版本进行覆盖。
4.2. 读取数据
读取数据的方法有两个: get 和 scan。
get 最大范围是一行数据,也可以进行列的过滤,读取数据的结果为多行 cell。
get 'bigdata:student','1001'
get 'bigdata:student','1001' , {COLUMN => 'info:name'}
也可以修改读取 cell 的版本数,默认读取一个。最多能够读取当前列族设置的维护版本数。
get 'bigdata:student','1001' , {COLUMN => 'info:name', VERSIONS => 6}
scan 是扫描数据,能够读取多行数据,不建议扫描过多的数据,推荐使用 startRow 和 stopRow 来控制读取的数据,默认范围左闭右开。
scan 'bigdata:student',{STARTROW => '1001',STOPROW => '1002'}
注意:实际开发中使用 shell 的机会不多,一般都是使用 API 进行数据的操作。
4.3. 删除数据
删除数据的方法有两个: delete 和 deleteall。
delete 表示删除一个版本的数据,即为 1 个 cell,不填写版本默认删除最新的一个版本。
delete 'bigdata:student','1001','info:name'
deleteall 表示删除所有版本的数据,即为当前行当前列的多个 cell。 (执行命令会标记数据为要删除,不会直接将数据彻底删除,删除数据只在特定时期清理磁盘时进行)
deleteall 'bigdata:student','1001','info:name'
注:其他HBase相关系列文章链接由此进 -> HBase文章汇总
相关文章
- hbase shell学习-2
- 一条数据的HBase之旅,简明HBase入门教程4:集群角色
- 一条数据的HBase之旅,简明HBase入门教程1:开篇
- Linux Shell脚本自动化编程实战- shell函数
- Linux Shell脚本自动化编程实战-shell变量(二)
- Linux Shell脚本自动化编程实战-shell变量(一)
- 大叔问题定位分享(49)hbase集群重启后master初始化失败
- Hbase 学习(十一)使用hive往hbase当中导入数据
- hbase源码系列(四)数据模型-表定义和列族定义的具体含义
- Linux Shell脚本自动化编程实战- shell内置命令 break、continue
- k8s部署hbase 2.2.6(含docker、helm部署方案)
- 启动HBase抛出org.apache.hadoop.hbase.ClockOutOfSyncException异常:hmaster正常,节点hregionserver启动失败
- HBase(2) Java 操作 HBase 教程
- 19.第六章 Shell脚本编程基础入门 -- shell 脚本语言的基本用法(二)
- 【Linux之Shell脚本实战】猜拳小游戏shell脚本
- MYSQL提权之反弹SHELL——数据库提权属于webshell到管理员的纵向提权,本质还是利用udf提权,无非是在mysql自定义函数中使用了反弹shell而已
- shell变量替换 SHELL字符串处理技巧(${}、##、%%)
- HBase启动RegionServer时报UnknownHostException错误的解决方法
- 线上问题排查-HBase写数据出现NotServingRegionException(Region ... is not online)异常
- shell - 07 - Shell文本处理三剑客 - grep
- shell - 08 - Shell文本处理三剑客 - sed -编辑命令详解