hbase rowkey 实现分页

本文探讨了在HBase中如何利用RowKey实现分页查询。通过介绍RowKey的生成规则,如(rowkey = (mall_id%100)(mall_id)(biz_type)(date)(row_number)),并结合分页参数(page, pageSize),计算startRowkey和endRowKey,以实现高效的数据分页浏览。" 79102592,7398620,Fedora 23中解决GigaRay board bitbake构建问题,"['嵌入式开发', 'Linux发行版', '软件构建', '系统配置']
摘要由CSDN通过智能技术生成

hbase 是根据rowkey查询的,ScanRows prefixFilter等过滤
要实现分页只能从rowkey下手
rowkey生成规则
rowkey = (mall_id%100)(mall_id)(biz_type)(date)(row_number)

row_number 从 00001 到010001这样下去 我们拿count只需要反向拿到最后一条解析下rowkey
分页根据 page pagesize 计算 startRowkey endRowKey

 @Override
    public List<Map<String, String>> queryOneByRowPrefixAndReversed(String tableName, String prefix, Boolean isReversed) throws IOException {
        Scan scan = generatePrefixScan(prefix);
        FilterList filterList = new FilterList(FilterList.Operator.MUST_PASS_ALL);
        Filter pageFilter = new PageFilter(1);
        filterList.addFilter(pageFilter);
        scan.setFilter(filterList);
        scan.setReversed(isReversed);
        if (isReversed) {
            byte[] startRow = scan.getStartRow();
            scan.setStartRow(scan.getStopRow());
            scan.setStopRow(startRow);
        }
        return getScanResult(sc
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值