zoukankan      html  css  js  c++  java
  • Hbase之取出行数据指定部分(类似MySQL的Limit)

    import org.apache.hadoop.conf.Configuration;
    import org.apache.hadoop.hbase.CellScanner;
    import org.apache.hadoop.hbase.HBaseConfiguration;
    import org.apache.hadoop.hbase.TableName;
    import org.apache.hadoop.hbase.client.*;
    import org.apache.hadoop.hbase.util.Bytes;
    
    import java.io.IOException;
    import java.util.ArrayList;
    import java.util.List;
    
    /**
     * Created by similarface on 16/8/22.
     * 这儿实现了一个类似于MySQL的Limit的功能
     */
    public class RetrievesPartsRowWithOffsetLimit {
        public static void main(String args[]) throws IOException {
            Configuration configuration = HBaseConfiguration.create();
            Connection connection = ConnectionFactory.createConnection(configuration);
            //建立表的连接
            Table table = connection.getTable(TableName.valueOf("testtable"));
            Put put = new Put(Bytes.toBytes("5701"));
            for (int n = 1; n <= 1000; n++) {
                String num = String.format("%04d", n);
                put.addColumn(Bytes.toBytes("colfam1"), Bytes.toBytes("qual"+num), Bytes.toBytes("val" + num));
            }
            table.put(put);
            Get get1 = new Get(Bytes.toBytes("5701"));
            //要求最多返回10个Cell
            get1.setMaxResultsPerColumnFamily(10);
            Result result1 = table.get(get1);
            CellScanner scanner1 = result1.cellScanner();
            //返回1-10的数据集
            while (scanner1.advance()) {
                System.out.println("Get 1 Cell: " + scanner1.current());
            }
    
            Get get2 = new Get(Bytes.toBytes("5701"));
            //要求最多返回10行
            get2.setMaxResultsPerColumnFamily(10);
            //跳过前面100
            get2.setRowOffsetPerColumnFamily(100);
            Result result2 = table.get(get2);
            CellScanner scanner2 = result2.cellScanner();
            //返回101-110的数据
            while (scanner2.advance()) {
                System.out.println("Get 2 Cell: " + scanner2.current());
            }
        }
    }
    /**
     result:
     Get 1 Cell: 5701/colfam1:qual0001/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0002/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0003/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0004/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0005/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0006/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0007/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0008/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0009/1471842173521/Put/vlen=7/seqid=0
     Get 1 Cell: 5701/colfam1:qual0010/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0101/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0102/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0103/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0104/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0105/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0106/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0107/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0108/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0109/1471842173521/Put/vlen=7/seqid=0
     Get 2 Cell: 5701/colfam1:qual0110/1471842173521/Put/vlen=7/seqid=0
     **/
    
  • 相关阅读:
    云服务器迁移的那些事之一
    《编译原理》(第二版)第一章的学习笔记(一)
    vs 实用扩展
    SQL多的是,你不知道的事
    Entity Framework 批量插入 提速
    oracle 回收已删除的表
    发现一个奇怪的问题!
    看到易办网的希望...
    asp.net不认为数据库字段的空值为null
    什么是伪url?
  • 原文地址:https://www.cnblogs.com/similarface/p/5795207.html
Copyright © 2011-2022 走看看