HBase Shell 操作

1、基本操作

1.1、进入HBase客户端命令行

前提是先启动hadoop集群和zookeeper集群。

bin/hbase shell

1.2、查看帮助命令

help

help 查看指定命令的语法规则

查看 list_namespace 的用法('记得加单引号')

bash 复制代码
help 'list_namespace'

2、namespace

我们首先查看现在有哪些命名空间 ,使用指令:list_namespace

注意:我的hadoop版本3.3.0,HBase2.4.17,两者兼容性有问题,我们直接使用上面的命令会报错,需要做两点:

  1. 确保 hadoop 退出安全模式
XML 复制代码
hadoop dfsadmin -safemode leave
  1. 在hbase-site.xml 中添加下面的配置
XML 复制代码
<property>
    <name>hbase.wal.provider</name>
    <value>filesystem</value>
</property>

执行语句 list_namespace

2.1、创建命名空间

通过 help 查看创建命名空间的用法:

我们可以看到,我们可以通过两种方式创建 namespace。

创建命名空间 bigdata

3、DDL

3.1、查看表格

bash 复制代码
list

3.2、创建表格

案例1

在我们的命名空间 bigdata 下创建一个表格 student 并指定两个列族 info 和 msg

如果不指定命名空间的话也可以,这时候使用的是HBase默认的 default 命名空间。

不指定版本空间的话默认版本空间是1,后续可以修改。

bash 复制代码
create 'bigdata:student','info','msg'

去web端查看:

案例2

同样在命名空间 bigdata 下再创建一个表 person ,指定两个列族 info 和 msg 并指定保留5个历史版本。

每次修改都会将新值追加到版本列表中,同时删除旧版本,以保持每个单元格的版本数不超过创建时指定的值。

bash 复制代码
create 'bigdata:person',{NAME => 'info',VERSIONS => 5},{NAME => 'msg',VERSIONS => 5}

3.3、查看表的详细信息

bash 复制代码
describe '命名空间:表名'

3.4、修改表

我们在创建表的时候指定的所有列族相关的信息,都可以后续通过 alter 进行修改,包括增加删除列族,这也是为什么说 HBase 是稀疏的,因为这些列族都是可以后续我们一直增加修改的,包括列族下的列,我们到现在还没有创建真正的列,需要的时候再去创建。

3.4.1、增加列族和修改列族

修改列族版本空间

bash 复制代码
alter 'bigdata:student',NAME => 'info',VERSIONS => 5

增加列族 'info1'

bash 复制代码
alter 'bigdata:student',NAME => 'info1',VERSIONS => 5

3.4.2、删除列族

两种删除方法:

bash 复制代码
alter '命名空间:表名',NAME => '列族',METHOD => 'delete'

或者

bash 复制代码
alter '命名空间:表名','delete' => '列族'

命名空间为 default 命名空间可以省去不写,下面都是如此。

3.5、删除表

HBase中删除表格时必须先标记为 Disable 不可用的,才能再删除。

3.5.1、disable

bash 复制代码
disable '命名空间:表名'

3.5.2、drop

bash 复制代码
drop '命名空间:表名'

4、DML

4.1、写入数据

HBase中写入的数据只能是结构中最底层的 cell (由{rowkey, column Family : column Qualifier, timestamp} 唯一确定的单元)。

学会多用 help 去查看用法:

语法:

bash 复制代码
put '命名空间:表名','行号','列族:列名','值'

其中的行号和列名都是新增数据的时候才增加的,我们在创建表的时候并不需要定义,再次体现了NoSQL数据库的稀疏性。

4.2、读取数据

4.2.1、get

读取某一行的数据

bash 复制代码
get '命名空间:表名','行号'

也可以进行列的过滤:

bash 复制代码
get '命名空间:表名','行号',{COLUMN => '列族:列名'}

限定多列:

bash 复制代码
get '命名空间:表名','行号',{COLUMN => ['列族:列名','列族:列名','列族:列名'...]}

读取多个版本:比如读取6个版本的历史数据(注意:我们读取到的版本数不会操作它维护的版本数,即我们定义时设置的版本数)

bash 复制代码
get '命名空间:表名','行号',{COLUMN => '列族:列名',VERSIONS => 6}

4.2.2、scan

扫描整张表

get 只能读取一行数据,我们希望读取多行数据的话就要使用scan了,scan的时候默认读取的是我们最新的版本。

bash 复制代码
scan '命名空间:表名'
扫描指定范围

通过指定开始和结束行号来输出指定范围的数据,所以说在HBase中,行号的设计很重要。

注意:STARTROW 到 STOPROW 是左闭右开的

bash 复制代码
scan '命名空间:表名',{STARTROW => '行号',STOPROW => '行号'}

4.3、删除数据

删除数据有两个方法:deletedeleteall ,前者是删除一个版本的数据,后者是删除所有版本的数据。

4.3.1、delete

delete 默认删除最新的一个版本。

bash 复制代码
delete '命名空间:表名','列族:列名'

4.3.2、deleteall

bash 复制代码
deleteall '命名空间:表名','列族:列名'
相关推荐
floret*8 分钟前
在 hiveSQL 中判断一个字段是否包含某个值
前端·javascript·数据库
冰红茶兑滴水28 分钟前
MySQL 数据库之库操作
数据库·mysql
Fireworkitte1 小时前
MongoDB
数据库·mongodb
来一杯龙舌兰2 小时前
【MongoDB】MongoDB的聚合(Aggregate、Map Reduce)与管道(Pipline) 及索引详解(附详细案例)
数据库·mongodb·mapreduce·索引·aggregate·pipline
爱吃烤鸡翅的酸菜鱼3 小时前
MySQL初学之旅(1)配置与基础操作
java·数据库·mysql·database
三日看尽长安花5 小时前
【分布式数据库】
数据库·分布式
一 乐9 小时前
家常菜点餐|基于java和小程序的家庭大厨家常菜点餐系统设计与实现(源码+数据库+文档)
java·数据库·小程序·家庭点餐小程序·家庭家常菜点餐
小小不董9 小时前
Oracle OCP认证考试考点详解082系列08
linux·运维·服务器·数据库·oracle·dba
王哲晓10 小时前
第一章 微服务入门
java·数据库·微服务
DarkAthena10 小时前
【MogDB】MogDB5.2.0重磅发布第五篇-支持部分ORACLE的HINT
数据库·oracle·opengauss