HBase(3):HBase Shell 操作

news/2025/3/19 18:29:09/

目录

0. 相关文章链接

1. 基本操作

2. namespace

3. DDL

3.1. 创建表

3.2. 查看表

3.3. 修改表

3.4. 删除表

4. DML

4.1. 写入数据

4.2. 读取数据

4.3. 删除数据


0. 相关文章链接

 HBase文章汇总

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文章汇总 



http://www.ppmy.cn/news/341410.html

相关文章

HW3000无线芯片模块

HW3000超低双向无线fsk模块完美替代CC1101、CC1120、A7139、A7108、si4432、si4438、si4463 转载于:https://my.oschina.net/u/2970238/blog/761348

SV枚举类型转化、数组、字符串使用小结

目录 一、枚举类型转化 二、结构体 三、合并数组和非合并数组 1、非组合型 2、组合型 3、数组中数据查找 四、字符串string 五、关联数组 一、枚举类型转化 将1转换成枚举类型st2 state_t(1),可以成功转换。 将4转换成枚举类型st2 state_t(4); 超出范围&a…

hbase HFile V3介绍

HBase 0.98开始增加了对cell tags的支持,所以其HFile结构也发生了改变。HFile V3的格式只是在V2格式后增加了标签部分。其他保持不变,所以对V2保持了兼容性。用户可以从V2直接切换到V3。 HFile V3主要的提高是压缩比和,通过把key放在一起 Val…

H3C UniServer R6900 G3 服务器介绍

一、H3C UniServer R6900 G3服务器产品概述 全新H3C UniServer R6900 G3服务器产品家族 H3C UniServer R6900 G3服务器介绍: H3C R6900 G3机架式服务器是自主研发的,基于IntelXeonScalable Processor的新一代4U机架式服务器,可广泛应用于新…

每个DBA都应该知道:进行数据库优化的方法

优化操作数据库及其访问应用的性能是数据库管理员(DBA)持续进行的挑战。当然,编写高效的SQL是确保数据库优化性能的最重要方面,但是对SQL的调整或系统的调优都无法优化针对设计不良或组织混乱的数据库运行的查询的性能。因此&…

102. 二叉树的层序遍历

2023.6.12 思路就是用队列,保存完一层后,开始取出,取出一个保存它的值,然后把它的左右孩子添加到队列的尾部,这样当一层的值保存完后,其下一层的所有节点正好全部进入队列。 # Definition for a binary tr…

回调函数排序异常原因

回调函数排序异常原因 问题所在解决方案 参考我的这篇博文c回调函数排序:回调函数 我之前的代码是这样写的:(存在问题) 问题所在 将数组传递到其他函数中,再使用sizeof(数组名),得到的不是数组的完成长度了(往往会短一些) 解决…

排水管网监测,万宾排水管网在线监测系统

城市排水管网是保障城市环境卫生的重要基础设施。然而,传统的排水管网管理方式存在许多问题.通过排水管网在线监测系统的建设,可以实现对管网上窨井井盖状态、管网液位、管网流量、管网水质等数据采集,实时掌握排水管网运行状况,为…