为了账号安全,请及时绑定邮箱和手机立即绑定

hbase 多条件查询or 怎么过滤掉不需要查的列

hbase 多条件查询or 怎么过滤掉不需要查的列

慕码人2483693 2018-10-02 13:13:50
查看完整描述

2 回答

?
蛊毒传说

TA贡献1895条经验 获得超3个赞

hbase提供了ListFilter过滤
List<Filter> filters = new ArraList<Filter>();
Filter f1=new RowFilter(.........);
Filter f2=new AualifierFilter(................);
filters.add(f1);
filters.add(f2);
FilterList filterList=new FilterList(filters);
Scan scan=new Scan();
scan.setFilter(filterList);
ResultScanner scanner=table.getScanner(scan);
之后遍历就ok了

查看完整回答
反对 回复 2018-10-26
?
拉风的咖菲猫

TA贡献1995条经验 获得超2个赞

hbase的region是按行划分,而非按列,如果你读取指定一行的所有列数据,regionServer虽然无法保证你的所有数据都在一个HFile中,但是至少是在一个Region中。但是具体的HFile所在的hdfs的节点那就不是HBase关心的事了,因为HBase的存储是依赖与hdfs,所以底层存储读取的事会由NameNode操心,NameNode会考虑就近原则,而提供最高效的数据读取策略。
你的数据传输是必然,但是HBase不会计算,计算是发生在你将想要的数据获取到之后再自行进行计算的。你读取大量数据必然会有大量数据传输,HBase只是将提供了一种高效的数据读取策略,尽量减小数据传输量

查看完整回答
反对 回复 2018-10-26
  • 2 回答
  • 0 关注
  • 1955 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信