rowkey
rowkey是行的主键,而且hbase只能用个rowkey,或者一个rowkey范围即scan来查找数据。所以 rowkey的设计是至关重要的,关系到你应用层的查询效率。我们知道,rowkey是以字典顺序排序的。而存储的字节码,字典排序,我们知道,如果是字 母,那就是字母的顺序,比如,有两个rowkey,rowkey1:aaa222,rowkey2:bbb111,那么rowkey1是排在 rowkey2前面的,因为按字典,a排在b前面,如果rowkey2的第一位也是a,那么就根据第二位来比较,如果还相同,则比较第三为,后面同样。这 个理解了,我们在根据rowkey范围查询的时候,我们一般是知道startRowkey,如果我们通过scan只传startRowKey : d开头的,那么查询的是所有比d大的都查了,而我们只需要d开头的数据,那就要通过endRowKey来限制。我们可以通过设定endRowKey为:d 开头,后面的根据你的rowkey组合来设定,一般是加比startKey大一位。比如说rowkey设计为:用户ID-日期,那么查某个用户某天的数 据,startKEY为3231-20121212,endKey为:3231+201213,那么你查到的就是用户为3231在20121212这一天 的数据。
column key
column key是rowkey之后,数据按rowkey字典排序后,如果rowkey相同,则是根据column key来排序的,也是按字典排序。
我们在设计table的时候要学会利用这一点。比如我们的收件箱。我们有时候需要按主题排序,那我们就可以把主题这设置为我们的column key,即设计为columnFamily+主题.,这样的设计。
timestamp
timestamp 时间戳,是第三维,这是个按降序排序的,即最新的数据排在最前面
详细解决方案
hbase数据的存放顺序
热度:25 发布时间:2023-09-19 00:02:00.0
相关解决方案
- Hbase 应用 -常用-
- HBase Java Api Eclipse开发(4)
- 【hbase】——bulk load导入数据时value=\x00\x00\x00\x01有关问题解析
- 凤凰错误:hbase 表未定义,即使它存在
- 如何创建 2 个以上的 HBase 表?
- HBase Scan基于特定的HFile作为根
- HBase Region自动切分的所有细节都在这里了
- 1.12 Flink HBase SQL 连接器
- spark-streaming连接hive+HBase
- hbase shell 操作失败查看日志遇到的一个bug
- Hbase 常用 Shell命令
- Hbase 启动报错
- 打开和关闭Hadoop,Hbase 命令
- hbase 0.94 安装
- Hbase 创建表 shell 命令
- Ubuntu Install Hbase 单机和多机
- Hbase 相关概念
- hbase shell Hbase模糊查询id不根据时间
- hbase thrift连不上的错误(client.RpcRetryingCaller: Call exception)
- HBase Memstore理解笔记
- hbase 写入性能
- hbase example code
- 0924 hbase
- Hadoop、HBase、ZooKeeper三者部署与关系
- Hadoop生态圈基础(zookeeper,hdfs,yarn,MR,hbase,hive)
- hbase运行时ERROR:org.apache.hadoop.hbase.PleaseHoldException:Master is initializing的解决方法
- HBase | 操作和性能配置选项
- HBase Shell输入命令无法删除问题解决技巧
- HBase Exists
- HBase Admin API