【HBase】——Shell操作
2024-01-02 18:53:48
1 基本操作
1.1 进入 HBase 客户端命令行
bin/hbase shell
1.2 查看帮助命令
能够展示 HBase 中所有能使用的命令,主要使用的命令有 namespace 命令空间相关, DDL 创建修改表格,DML 写入读取数据。
help
1.2 namespace
1)创建命名空间
create_namespace 'test_namespace';
3)查看所有的命名空间
list_namespace;
2 DDL
2.1 创建表
在 bigdata 命名空间中创建表格 student,两个列族。info 列族数据维护的版本数为 5 个, 如果不写默认版本数为 1。
create 'test_namespace:student', {NAME => 'info', VERSIONS => 5}, {NAME => 'msg'}
如果创建表格只有一个列族,没有列族属性,可以简写。 如果不写命名空间,使用默认的命名空间 default。
create 'student1','info'
2.2 查看表
查看表有两个命令:list 和 describe list:查看所有的表名
list
describe:查看一个表的详情
describe 'student1';
2.3 修改表
表名创建时写的所有和列族相关的信息,都可以后续通过 alter 修改,包括增加删除列 族。
(1)增加列族和修改信息都使用覆盖的方法
alter 'test_namespace.student', {NAME => 'f1', VERSIONS => 3};
(2)删除信息使用特殊的语法
alter 'test_namespace.student', NAME => 'f1', METHOD => 'delete';
或
alter 'test_namespace.student', 'delete' => 'f1';
2.4 删除表
shell 中删除表格,需要先将表格状态设置为不可用。
disable 'test_namespace.student';
drop 'test_namespace.student';
3 DML
3.1 写入数据
在 HBase 中如果想要写入数据,只能添加结构中最底层的 cell。可以手动写入时间戳指 定 cell 的版本,推荐不写默认使用当前的系统时间。
put 'test_namespace:student','1001','info:name','zhangsan'
put 'test_namespace:student','1002','info:name','lisi'
put 'test_namespace:student','1003','info:age','18'
3.2 读取数据
读取数据的方法有两个:get 和 scan。
3.2.1 get
get 最大范围是一行数据,也可以进行列的过滤,读取数据的结果为多行 cell。
get 'test_namespace:student','1003'
过滤列
get 'test_namespace:student','1001', {COLUMN => ['info:name']}
过滤版本
也可以修改读取 cell 的版本数,默认读取一个。最多能够读取当前列族设置的维护版本数。
get 'test_namespace:student','1001' , {COLUMN => ['info:name'], VERSIONS => 2}
3.2.1 scan
scan 是扫描数据,能够读取多行数据,不建议扫描过多的数据,推荐使用 startRow 和 stopRow 来控制读取的数据,默认范围左闭右开。
scan 'test_namespace:student'
scan 'test_namespace:student', {STARTROW => '1001',STOPROW => '1002'}
3.3 删除数据
3.3.1 delete
delete 表示删除一个版本的数据,即为 1 个 cell,不填写版本默认删除最新的一个版本。
delete 'test_namespace:student','1001','info:name'
3.3.2 deleteall
deleteall 表示删除所有版本的数据,即为当前行当前列的多个 cell。(执行命令会标记 数据为要删除,不会直接将数据彻底删除,删除数据只在特定时期清理磁盘时进行)
deleteall 'test_namespace:student','1001','info:name'
文章来源:https://blog.csdn.net/qq_42000631/article/details/135346227
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!