HBase 数据模型

在HBase中,数据存储在表中,表有行和列,这看起来跟关系型数据库类似,但其实又不同。下面具体介绍一下HBase中的结构,

表(TABLE)
一个HBase表包含多行。

行(Row)
行由行键(row key)及一或多个相关的列组成。行是按照行键存储的,因此合理的设计行键十分重要。由此可以看出,HBase表类似于一个索引的结构。

列(Column)
一个列由列族和列标识符组成,列族和列标识符以:分隔。

列族(Column Family)
从物理存储的角度,一个列族包含一组列及其中的值。每个列族都有一些存储相关的属性,如数据是否缓存、数据是否压缩、行键是否编码等等。HBase中的每行都具有相同的列族,即便一个固定的行可能什么数据都没有。

列标识(Column Qualifier)
列标识在列族中用来指向某一块特定的数据。比如,列族如为content,一个列标识为content:html,另一个列标识为content:pdf。列族一般在创建表的时候就固定下来,而列标识则是可以在任意时间随时添加到一个列族中。

单元格(Cell)
单元格由行键、列族、列标识组成,并包含具体的数据及一个时间戳,时间戳代表了数据的版本。

时间戳(Timestamp)
HBase中表都中的数据都有时间戳,代表数据的版本。默认情况下为数据被写入的时间,也可以自己指定。

下面是一个HBase的样例表,

这里写图片描述

实质上,HBase是一个Key-Value的存储形式,这可以通过下图很好的理解,

这里写图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据源的港湾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值