文档章节

HBase Filter使用方法

z
 zongze30
发布于 2015/01/30 14:23
字数 327
阅读 147
收藏 0

这几年hadoop实在是比较火,但是相信随着时间的推移,肯定会慢慢降温,hadoop之后将会有哪些技术火起来呢,我们拭目以待吧。

一、FilterList

1
2
3
  // 通过将operator参数设置为Operator.MUST_PASS_ONE,达到list中各filter为"或"的关系   or
  // 默认operator参数的值为Operator.MUST_PASS_ALL,即list中各filter为"并"的关系       and
     FilterList f= new  FilterList(FilterList.Operator.MUST_PASS_ONE);


二、几大Filter

1、Comparision Filters

      1.1 RowFilter    

1.2 FamilyFilter

      1.3 QualifierFilter     

      1.4 ValueFilter

      1.5 DependentColumnFilter ×

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 ×

3、Decorating Filters

      3.1 SkipFilter ×

      3.2 WhileMatchFilters ×






1.1   RowFilter  

格式:RowFilter(CompareFilter.CompareOp rowCompareOp, ByteArrayComparable rowComparator)


参数一  Operator Description


LESS 小于

LESS_OR_EQUAL 小于等于

EQUAL 等于

NOT_EQUAL 不等于

GREATER_OR_EQUAL 大于等于

GREATER 大于

NO_OP 排除所有


参数二  ByteArrayComparable  可用

BinaryComparator, BinaryPrefixComparator, BitComparator, LongComparator, NullComparator, RegexStringComparator, SubstringComparator


例子:Filter filter=new RowFilter(CompareOp.EQUAL, new BinaryComparator(Bytes.toBytes(RowKey))


相关的过滤方法使用:

提取rowkey以01结尾数据--正则表达式

Filter filter = new RowFilter(CompareFilter.CompareOp.EQUAL,new RegexStringComparator(".*01$"));


提取rowkey以包含201407的数据

Filter filter = new RowFilter(CompareFilter.CompareOp.EQUAL,new SubstringComparator("201407"));



提取rowkey以123开头的数据

Filter filter = new RowFilter(CompareFilter.CompareOp.EQUAL,new BinaryPrefixComparator("123".getBytes()));


提取rowkey小于等于row010的行

Filter filter1 = new RowFilter(CompareFilter.CompareOp.LESS_OR_EQUAL,new BinaryComparator("row010".getBytes()));

 1.2   FamilyFilter(同上)

1.3   QualifierFilter(同上)--------当列为数字,不管用了?why--------

1.4   ValueFilter(同上)

1.5   DependentColumnFilter    


© 著作权归作者所有

共有 人打赏支持
z
粉丝 0
博文 7
码字总数 1170
作品 0
石家庄
HBase shell的基本用法

hbase提供了一个shell的终端给用户交互。使用命令hbaseshell进入命令界面。通过执行 help可以看到命令的帮助信息。 以网上的一个学生成绩表的例子来演示hbase的用法。 name grad course mat...

超人学院
2015/05/27
0
0
基于solr实现hbase的二级索引

基于solr实现hbase的二级索引 [X] 目的: 由于hbase基于行健有序存储,在查询时使用行健十分高效,然后想要实现关系型数据库那样可以随意组合的、、等就比较麻烦了。想要实现这样的功能,我们可...

白石
2015/01/16
0
7
Hbase 学习(二)补充 自定义filter

本来这个内容是不单独讲的,但是因为上一个页面太大,导致Live Writer死机了,不能继续编辑了,所以就放弃了 这里要讲的是自定义filter,从FilterBase继承 public class CustomFilter extend...

2k10
2015/05/11
0
0
云HBaseSQL及分析-Phoenix&Spark

在2018年1月的数据库直播大讲堂峰会HBase专场,来自阿里云的研发工程师瑾谦和沐远分享了云HBaseSQL以及分析Phoenix&Spark。本文介绍了详细了Phoinix和Spark的架构,适用性以及优缺点,并在最...

HBase技术社区
06/05
0
0
技术大牛论道HBase 3.0 可能的新特性

本文内容根据第一届中国HBase技术社区上的演讲视频以及PPT整理而成。 其实,开源社区一直在反思为什么HBase 2.0经历了那么长的时间还是没有发布出来。社区也不希望在发布HBase 3.0版本的时候...

HBase技术社区
06/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

kubeadm部署kubernetes集群

一、环境要求 这里使用RHEL7.5 master、etcd:192.168.10.101,主机名:master node1:192.168.10.103,主机名:node1 node2:192.168.10.104,主机名:node2 所有机子能基于主机名通信,编辑...

人在艹木中
38分钟前
2
0
Shell特殊符号总结以及cut,sort,wc,uniq,tee,tr,split命令

特殊符号总结一 * 任意个任意字符 ? 任意一个字符 # 注释字符 \ 脱义字符 | 管道符 # #号后的备注被忽略[root@centos01 ~]# ls a.txt # 备注 a.txt[root@centos01 ~]# a=1[root@centos01...

野雪球
今天
2
0
OSChina 周二乱弹 —— 程序员圣衣

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @达尔文:分享Skeeter Davis的单曲《The End of the World》 《The End of the World》- Skeeter Davis 手机党少年们想听歌,请使劲儿戳(这里...

小小编辑
今天
13
0
[ python import module ] 导入模块

import moudle_name ----> import module_name.py ---> import module_name.py文件路径 -----> sys.path (这里进行查找文件) # from app.web import Personimport app.web.Person as Pe......

_______-
昨天
5
0
Redis性能问题排查解决手册

一、性能相关的数据指标 通过Redis-cli命令行界面访问到Redis服务器,然后使用info命令获取所有与Redis服务相关的信息。通过这些信息来分析文章后面提到的一些性能指标。 nfo命令输出的数据可...

IT--小哥
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部