HBase Filter使用方法(二)
admin
2023-02-08 06:20:05
0

2、Dedicated Filters

        2.1 SingleColumnValueFilter

      2.2 SingleColumnValueExcludeFilter

      2.3 PrefixFilter

      2.4 PageFilter

      2.5 KeyOnlyFilter

      2.6 FirstKeyOnlyFilter

      2.7 TimestampsFilter ×

      2.8 RandomRowFilter


2.1   SingleColumnValueFilter

             例子:Filter filter=new SingleColumnValueExcludeFilter(Bytes.toBytes(Family), Bytes.toBytes(Qualifier), CompareOp.EQUAL, Bytes.toBytes(Value));

       2.2   SingleColumnValueExcludeFilter

               使用:跟singlecolumnvaluefilter正好相反,这个是显示表中除了过滤的这条以外的所有数据 

               例子:

Filter filter=new SingleColumnValueExcludeFilter(Bytes.toBytes(Family), Bytes.toBytes(Qualifier), CompareOp.EQUAL, Bytes.toBytes(Value));
((SingleColumnValueExcludeFilter) filter).setFilterIfMissing(true);

               注意:!需要加((SingleColumnValueExcludeFilter) filter).setFilterIfMissing(true); 

2.3   PrefixFilter   和ColumnPrefixFilter    

              使用:根据Row或Column的前缀取数据

              例子:Filter filter=new PrefixFilter(Bytes.toBytes("r"));

                    取出RowKey以r开头的所有数据

2.4    PageFilter

               通过设置pageside返回每一页page的数量

final byte[] POSTFIX = new byte[] { 0x00 };  
        HTable table;
try {
table = new HTable(config, tablename);
Filter filter = new PageFilter(pageside);  
        byte[] lastRow = null;  
        int totalRows = 0;  
        while (true) {  
            Scan scan = new Scan();  
            scan.setFilter(filter);  
            if(lastRow != null){  
                //注意这里添加了POSTFIX操作,不然死循环了  
                byte[] startRow = Bytes.add(lastRow,POSTFIX);  
                scan.setStartRow(startRow);  
            }  
            ResultScanner scanner = table.getScanner(scan);  
            int localRows = 0;  
            Result result;  
            while((result = scanner.next()) != null){  
                System.out.println(localRows++ + ":" + result);  
                totalRows ++;  
                lastRow = result.getRow();  
            }  
            scanner.close();  
            if(localRows == 0) break;  
        }  
        System.out.println("total rows:" + totalRows);  
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

2.5    KeyOnlyFilter

              

         * 一般与其他过滤器配合使用

* Filter:KeyOnlyFilter(boolean lenAsVal)

* lenAsVal默认为假,表示不把val的长度作为val。否则val的长度将作为val输出。

* 键过滤器可以简单的设置过滤的结果集中只包含键而忽略值,这里有一个选项可以把结果集的值保存为值的长度

             例子:Filter filter = new KeyOnlyFilter(false);  

2.6    firstkeyonlyFilter

            用法:同上,但仅会返回相同key的第一条kv

       2.8    RandomRowFilter  

              随即的返回row的数据,构造函数为

              RandomRowFilter(float chance)  

              chance取值为0到1.0,如果<0则为空,如果>1则包含所有的行。

              例子:Filter filter=new RandomRowFilter(0.5f)



                


相关内容

热门资讯

今日重大发现“开心游戏.是不是... 有 亲,根据资深记者爆料开心游戏是可以开挂的,确实有挂(咨询软件无需打开...
我来教教您“麻友圈2.怎么装挂... 网上科普关于“麻友圈2有没有挂”话题很是火热,小编也是针对麻友圈2作*弊开挂的方法以及开挂对应的知识...
最新引进“长虹大厅.是不是有挂... 您好:长虹大厅这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
今日重大通报“旺旺冲击麻将.有... 家人们!今天小编来为大家解答旺旺冲击麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
重磅消息“蜀山四川麻将.到底有... 有 亲,根据资深记者爆料蜀山四川麻将是可以开挂的,确实有挂(咨询软件无需...
火箭发射高度活跃 产业链上市公... 本报记者 丁蓉 近日,火箭发射活动十分密集。12月13日,快舟十一号遥八运载火箭在酒泉卫星发射中心发...
终于明白“边锋老友麻将.究竟有... 家人们!今天小编来为大家解答边锋老友麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
【第一财经】“丫丫古诗.辅助器... 家人们!今天小编来为大家解答丫丫古诗透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里买很...
我来教教您“新永和牛牛.开挂器... 有 亲,根据资深记者爆料新永和牛牛是可以开挂的,确实有挂(咨询软件无需打...
玩家分享攻略“十胡卡.辅助开挂... 家人们!今天小编来为大家解答十胡卡透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很多...