首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在hbase中存储分层数据的最佳方法

在hbase中存储分层数据的最佳方法
EN

Stack Overflow用户
提问于 2011-11-18 04:39:18
回答 1查看 4.6K关注 0票数 6

我有一个从客户端收到的分层XML文件,我需要将它存储在Hbase数据库中,因为我是新的Hbase我不能理解如何接近,你能指导我应该如何进行这种分层数据存储到Hbase。

提前感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-11-20 20:29:36

Hbase以列的格式存储数据。每条记录必须有一个唯一的键。可以动态创建子列,但不能创建主列。

例如,condider this xml。

代码语言:javascript
复制
<X1>
   <X2 name = "uniqueid">1</X2>
   <X3>
      <X4>value1</X4>
      <X5>value2</X5>
      <X6>
          <X7>value3</X7>
          <X8>value4</X8>
      </X6>
   </X3>
   <X7>value5</X7>
</X1>

在本例中,主列族将是X3和X7。行Id可以从X2中获取。您可以使用java api构造与此等效的Hbase条目,如下所示

代码语言:javascript
复制
Put p = new Put("/*put the unique row id */ ".getBytes() );

p.add("X3".getBytes(), "X4".getBytes(), value1.getBytes());

其中第一个参数是列族,第二个参数称为列限定符(子列)。

您还可以使用双参数构造函数,例如,

代码语言:javascript
复制
p.add("X3:X6:X7".getBytes(),value3);

然后是table.put(p)。就是这样!

票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8173983

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档