当前位置:   article > 正文

HBase Shell操作_hbase 进入

hbase 进入

HBase Shell操作

基本操作

1.进入HBase客户端命令行

[atguigu@hadoop102 hbase]$ bin/hbase shell
  • 1

2.查看帮助命令

hbase(main):001:0> help
  • 1

namespace

1)创建命名空间
使用特定的 help 语法能够查看命令如何使用。

hbase:002:0> help 'create_namespace'
  • 1

2)创建命名空间 bigdata

hbase:003:0> create_namespace 'bigdata'
  • 1

3)查看所有的命名空间

hbase:004:0> list_namespace
  • 1

3.查看当前数据库中有哪些表

hbase(main):002:0> list
  • 1

DDL

1.创建表

在 bigdata 命名空间中创建表格 student,两个列族。info 列族数据维护的版本数为 5 个,
如果不写默认版本数为 1。

hbase:005:0> create 'bigdata:student', {NAME => 'info', VERSIONS => 5}, {NAME => 'msg'}
  • 1

如果创建表格只有一个列族,没有列族属性,可以简写。
如果不写命名空间,使用默认的命名空间 default。

hbase:009:0> create 'student1','info'
  • 1
查看表

查看表有两个命令:list 和 describe
list:查看所有的表名

hbase:013:0> list
  • 1

describe:查看一个表的详情

hbase:014:0> describe 'student1'
  • 1

3)修改表
表名创建时写的所有和列族相关的信息,都可以后续通过 alter 修改,包括增加删除列
族。
(1)增加列族和修改信息都使用覆盖的方法

hbase:015:0> alter 'student1', {NAME => 'f1', VERSIONS => 3}
  • 1

(2)删除信息使用特殊的语法

hbase:015:0> alter 'student1', NAME => 'f1', METHOD => 'delete'
hbase:016:0> alter 'student1', 'delete' => 'f1'
  • 1
  • 2

4)删除表
shell 中删除表格,需要先将表格状态设置为不可用。

hbase:017:0> disable 'student1'
hbase:018:0> drop 'student1'
  • 1
  • 2

DML

2.插入数据到表

hbase(main):003:0> put 'student','1001','info:sex','male'
hbase(main):004:0> put 'student','1001','info:age','18'
hbase(main):005:0> put 'student','1002','info:name','Janna'
hbase(main):006:0> put 'student','1002','info:sex','female'
hbase(main):007:0> put 'student','1002','info:age','20'
  • 1
  • 2
  • 3
  • 4
  • 5

3.扫描查看表数据

hbase(main):008:0> scan 'student'
hbase(main):009:0> scan 'student',{STARTROW => '1001', STOPROW  => '1001'}
hbase(main):010:0> scan 'student',{STARTROW => '1001'}
  • 1
  • 2
  • 3

4.查看表结构

hbase(main):011:0> describe ‘student’
  • 1

5.更新指定字段的数据

hbase(main):012:0> put 'student','1001','info:name','Nick'
hbase(main):013:0> put 'student','1001','info:age','100'
  • 1
  • 2

如果重复写入相同 rowKey,相同列的数据,会写入多个版本进行覆盖。

6.查看“指定行”或“指定列族:列”的数据
读取数据
读取数据的方法有两个:get 和 scan。
get 最大范围是一行数据,也可以进行列的过滤,读取数据的结果为多行 cell。

hbase:022:0> get 'bigdata:student','1001'
hbase:023:0> get 'bigdata:student','1001' , {COLUMN => 'info:name'}
  • 1
  • 2

也可以修改读取 cell 的版本数,默认读取一个。最多能够读取当前列族设置的维护版本
数。

hbase:024:0>get 'bigdata:student','1001' , {COLUMN => 'info:name',
VERSIONS => 6}
  • 1
  • 2

scan 是扫描数据,能够读取多行数据,不建议扫描过多的数据,推荐使用 startRow 和
stopRow 来控制读取的数据,默认范围左闭右开。

hbase:025:0> scan 'bigdata:student',{STARTROW => '1001',STOPROW =>
'1002'}
  • 1
  • 2

实际开发中使用 shell 的机会不多,所有丰富的使用方法到 API 中介绍。

7.统计表数据行数

hbase(main):021:0> count 'student'
  • 1

8.删除数据
删除某rowkey的全部数据:

hbase(main):016:0> deleteall 'student','1001'
  • 1

删除某rowkey的某一列数据:

hbase(main):017:0> delete 'student','1002','info:sex'
  • 1

删除数据的方法有两个:delete 和 deleteall。
delete 表示删除一个版本的数据,即为 1 个 cell,不填写版本默认删除最新的一个版本。

hbase:026:0> delete 'bigdata:student','1001','info:name'
  • 1

deleteall 表示删除所有版本的数据,即为当前行当前列的多个 cell。(执行命令会标记
数据为要删除,不会直接将数据彻底删除,删除数据只在特定时期清理磁盘时进行)

hbase:027:0> deleteall 'bigdata:student','1001','info:name'
  • 1

9.清空表数据

hbase(main):018:0> truncate 'student'
  • 1

提示:清空表的操作顺序为先disable,然后再truncate。
10.删除表
首先需要先让该表为disable状态:

hbase(main):019:0> disable 'student'
  • 1

然后才能drop这个表:

hbase(main):020:0> drop 'student'
  • 1

提示:如果直接drop表,会报错:ERROR: Table student is enabled. Disable it first.
11.变更表信息
将info列族中的数据存放3个版本:

hbase(main):022:0> alter 'student',{NAME=>'info',VERSIONS=>3}
hbase(main):022:0> get 'student','1001',{COLUMN=>'info:name',VERSIONS=>3}
  • 1
  • 2
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/725722
推荐阅读
相关标签
  

闽ICP备14008679号