HBase 增删改查(CRUD)完整操作指南

HBase 是列式非关系型数据库 ,核心操作基于 行键 (RowKey)列族 (ColumnFamily)列 (Column)版本 (Version) 展开。我会用 HBase Shell 命令 (最常用)和 Java API 两种方式,完整演示增、删、改、查操作。

一、前置准备

先创建测试表(所有操作基于此表):

shell

复制代码
# 进入 HBase Shell
hbase shell

# 创建表:表名 test,列族 info、score
create 'test', 'info', 'score'

二、增(插入数据)

HBase 没有专门的 update 操作插入和修改共用 put 命令

  • RowKey 不存在 = 新增数据
  • RowKey 已存在 = 覆盖数据(修改)

1. Shell 方式

shell

复制代码
# 语法:put '表名', '行键', '列族:列', '值'
# 插入 3 条学生数据
put 'test', 'student_001', 'info:name', '张三'
put 'test', 'student_001', 'info:age', '20'
put 'test', 'student_001', 'score:math', '95'

put 'test', 'student_002', 'info:name', '李四'
put 'test', 'student_002', 'score:english', '88'

2. Java API 方式

java

运行

复制代码
// 核心:Put 对象插入数据
Put put = new Put(Bytes.toBytes("student_003"));
// 添加列族:列:值
put.addColumn(Bytes.toBytes("info"), Bytes.toBytes("name"), Bytes.toBytes("王五"));
put.addColumn(Bytes.toBytes("score"), Bytes.toBytes("math"), Bytes.toBytes("90"));
// 执行插入
table.put(put);

三、改(更新数据)

直接用 put 覆盖原有数据即可,HBase 会自动保留多版本(默认保留 1 个版本)。

1. Shell 方式

shell

复制代码
# 修改 student_001 的年龄为 21
put 'test', 'student_001', 'info:age', '21'

# 修改 math 成绩为 98
put 'test', 'student_001', 'score:math', '98'

2. Java API 方式

java

运行

复制代码
Put put = new Put(Bytes.toBytes("student_001"));
// 覆盖原有 age 值
put.addColumn(Bytes.toBytes("info"), Bytes.toBytes("age"), Bytes.toBytes("21"));
table.put(put);

四、删(删除数据)

HBase 支持三级删除:删除列 → 删除列族 → 删除整行。

1. Shell 方式

shell

复制代码
# 1. 删除指定列(最常用)
delete 'test', 'student_001', 'info:age'

# 2. 删除整行
deleteall 'test', 'student_002'

# 3. 清空整张表(保留表结构)
truncate 'test'

2. Java API 方式

java

运行

复制代码
// 1. 删除指定列
Delete delete = new Delete(Bytes.toBytes("student_001"));
delete.addColumn(Bytes.toBytes("info"), Bytes.toBytes("age"));
table.delete(delete);

// 2. 删除整行
Delete deleteAll = new Delete(Bytes.toBytes("student_002"));
table.delete(deleteAll);

五、查(查询数据)

配合增删改使用,验证结果。

1. Shell 方式

shell

复制代码
# 1. 查询单行数据(最常用)
get 'test', 'student_001'

# 2. 查询全表数据
scan 'test'

# 3. 查询指定列族/列
get 'test', 'student_001', 'info'
get 'test', 'student_001', 'score:math'

六、完整操作示例(Shell 一键复制执行)

shell

复制代码
# 1. 创建表
create 'test', 'info', 'score'

# 2. 新增数据
put 'test', 's001', 'info:name', '张三'
put 'test', 's001', 'info:age', '20'
put 'test', 's001', 'score:math', '95'

# 3. 修改数据
put 'test', 's001', 'info:age', '21'

# 4. 查询验证
get 'test', 's001'

# 5. 删除列
delete 'test', 's001', 'info:age'

# 6. 再次查询
get 'test', 's001'

# 7. 删除整行
deleteall 'test', 's001'

总结

  1. 增 / 改 :统一用 put,RowKey 不存在 = 新增,存在 = 修改
  2. delete 删列,deleteall 删行,truncate 清空表
  3. get 查单行,scan 查全表
  4. 核心定位:表名 + RowKey + 列族:列
相关推荐
2301_812539671 小时前
Redis怎样在Spring中执行批量Pipeline指令
jvm·数据库·python
噜噜噜阿鲁~1 小时前
python学习笔记 |10.1、面向对象编程-类和实例
笔记·python·学习
woxihuan1234561 小时前
Redis怎样定位每秒被高频访问的热点键
jvm·数据库·python
sleepcattt1 小时前
Spring-全面详解(学习总结)
数据库·sql·spring·spring事务·spring详解
wsj668881 小时前
04 | Prompt Engineering:提示词工程
python
Volunteer Technology1 小时前
Spring AI MCP案例
java·开发语言·数据库
郝学胜-神的一滴1 小时前
干货版《算法导论》04:渐近复杂度与序列接口实战
java·开发语言·数据结构·c++·python·算法
神明9311 小时前
CSS 背景图滑动切换:纯 CSS 实现右进左出轮播效果
jvm·数据库·python
星栈1 小时前
投影挂了怎么办?我的 CQRS 三层容错方案
数据库·后端·开源