【NoSQL数据库】Hbase基本操作——数据库表的增删改查

目录

一、Hbase原理

二、HBase数据库操作

三、遇到的问题和解决方法


一、Hbase原理

HBase的数据模型:

|---------------|-----|-----------------------------|----------------------------|-----------------------|
| 行键 | 时间戳 | 列族:contents | 列族:anchor | 列族:mime |
| "com.cnn.www" | T9 | | Achor:cnnsi.com="CNN" | |
| "com.cnn.www" | T8 | | Achor:my.lock.ca="CNN.com" | |
| "com.cnn.www" | T6 | Contents:html="<html>..." | | Mime:type="text/html" |
| "com.cnn.www" | T5 | Contents:html="<html>..." | | |
| "com.cnn.www" | T3 | Contents:html="<html>..." | | |

HBase是一个高可靠性、高性能、面向列、可伸缩的分布式数据库。利用HBase技术可在廉价的PC Server上搭建起大规模结构化存储集群。

HBase是非关系型数据库,它不要求数据之间有严格的关系,同时它允许在同一列不同行中存储不同类型的数据。Hbase作为Hadoop框架下的数据库,是被设计成在一个服务器集群上运行的。

二、HBase数据库操作

示例:在Hbase建立如下表格数据,表格命名为Phone,并对Phone表执行数据查询、修改、删除及表格的删除操作。

|------|--------|-------------|-------|--------|
| 行键 | info || sale | 时间戳 |
| 行键 | brand | name | price | 时间戳 |
| P001 | Apple | Iphone16 | 8999 | 202404 |
| P001 | | Iphone15 | | 202303 |
| P003 | HUAWEI | Mate 30 pro | 5999 | 201906 |

1、在虚拟机终端输入hbase shell进入hbase。

2、HBase创建数据库表

(1)建立数据库表,使用create '表名', '列族名1','列族名2','列族名N',具体操作如下所示。

(2)执行命令list查看所有数据库表,下图显示Phone表,说明已经创建成功。

(3)describe 'Phone'查看Phone表的结构。

(4)count 'Phone'查看Phone表中的所有记录数量,此时未添加数据,记录为0。

2、增加数据操作

put '表名','行键','列族:列','值',具体操作如下所示。对Phone表所有记录进行添加。

3、查询数据操作

(1)查看表的所有记录,使用 scan '表名',具体操作如下所示。

(2)查看某个行键下的所有记录,使用 get '表名','行键',具体操作如下所示。

(3)查看某个行键下的列族记录,使用get '表名','行键','列族',具体操作如下所示。

(4)查看列族的某个列记录,使用get '表名','行键','列族:列',具体操作如下所示。

3、更新数据操作

Hbase更新数据即追加数据,对相同行键、列族和列名的数据再次添加即为数据的更新,重写一遍进行覆盖实现更新。Phone表中要把P001的价格从8999更新为9888,具体操作如下所示。

4、删除数据操作

(1)删除某个列族中的列,使用delete'表名','行名','列族:列',具体操作如下所示。

(2)使用get查询删除是否成功,具体操作如下所示。

(3)删除整行记录,使用deleteall '表名','行键',具体操作如下所示。

(3)清空表所有记录,使用truncate '表名',具体操作如下所示。

5、删除数据表

(1)蔽数据表: disable '表名'

(2)查看表是否可用:is_enabled '表名'

(3)删除数据表:drop '表名'

具体操作如下所示。

三、遇到的问题和解决方法

我自己操作时遇到的问题和一些解决方法(大家可以在评论区讨论):

1、hbase shell命令回车后报错,提示zookeeper连接出现问题,后来发现是hbase-site.xml文件没有正确配置,正确配置后可以启动zookeeper,正常运行。(这里可以查看我的Hadoop和Hbase的配置文章,里面有说如何配置hbase-site.xml文件)

【Hadoop和Hbase集群配置】3台虚拟机、jdk+hadoop+hbase下载和安装、环境配置和集群测试_虚拟机hbase环境配置-CSDN博客

2、增加数据时,put之后没有报错,可是get和scan查看数据却没有显示内容,说明添加数据出现问题,我试了重新启动hbase服务,也没有解决,后来删除Phone表重新创建,就可以添加数据了。

3、Phone表里有一个时间戳为202303的P001记录,可是在已经添加了Iphone16的数据之后,Iphone15的就put失效,和上面的问题一样,或许是因为202303的记录比202404的记录要旧,被新时间戳的记录覆盖了,所以显示不了。

相关推荐
workflower19 小时前
软件需求规约的质量属性
java·开发语言·数据库·测试用例·需求分析·结对编程
悟纤19 小时前
Suno 爵士歌曲创作提示整理 | Suno高级篇 | 第22篇
大数据·人工智能·suno·suno ai·suno api·ai music
橘子1320 小时前
MySQL库的操作(二)
数据库·mysql·oracle
yl453020 小时前
污泥清淤机器人实践复盘分享
大数据·人工智能·机器人
todoitbo20 小时前
多模数据库技术解析:以KingbaseES MongoDB兼容版为例
数据库·mongodb·kingbasees·金仓数据库
正在走向自律20 小时前
ksycopg2实战:Python连接KingbaseES数据库的完整指南
数据库·python·国产数据库·kingbase·kingbasees·数据库平替用金仓·ksycopg2
B站计算机毕业设计超人20 小时前
计算机毕业设计Python+百度千问大模型微博舆情分析预测 微博情感分析可视化 大数据毕业设计(源码+LW文档+PPT+讲解)
大数据·hive·hadoop·python·毕业设计·知识图谱·课程设计
廋到被风吹走20 小时前
【数据库】【MongoDB】全栈深度指南:文档模型到分布式集群
数据库·分布式·mongodb
·云扬·20 小时前
MySQL各版本核心特性演进与主流分支深度解析
数据库·sql·mysql
砚边数影21 小时前
AI开发依赖引入:DL4J / Java-ML 框架 Maven 坐标配置
java·数据库·人工智能·深度学习·机器学习·ai·maven