hbase Filter

get和sacn可以用过滤器。1.FilterList    这是一个过滤器列表,可以指定FilterList.Operator.MUST_PASS_ALL(列表内的过滤器要全部满足,相当于与)和FilterList.Operator.MUST_PASS_ONE(列表的过滤器只要满足一项就行了,相当于或,这是默认)。list里面可以包含list。 Scan scan = new Sc
摘要由CSDN通过智能技术生成

    get和sacn可以用过滤器。

1.FilterList

    这是一个过滤器列表,可以指定FilterList.Operator.MUST_PASS_ALL(列表内的过滤器要全部满足,相当于与)和FilterList.Operator.MUST_PASS_ONE(列表的过滤器只要满足一项就行了,相当于或,这是默认)。list里面可以包含list。

		Scan scan = new Scan();
		scan.setStartRow("row0".getBytes());
		scan.setStopRow("row9".getBytes());
		
		FilterList list = new FilterList(FilterList.Operator.MUST_PASS_ALL);
		SingleColumnValueFilter scvf = new SingleColumnValueFilter(
				"f".getBytes(),"name".getBytes(), CompareOp.GREATER_OR_EQUAL, "name7".getBytes());
		
		SingleColumnValueFilter scvf2 = new SingleColumnValueFilter(
				"f".getBytes(),"name".getBytes(), CompareOp.LESS_OR_EQUAL, "name9".getBytes());
		
		list.addFilter(scvf2);
		list.addFilter(scvf);
		
		scan.setFilter(list);
CompareOp是一个枚举类型,有等于,不等于,大于,大于或等于,小于,小于或等于,no operation。


2.SingleColumnValueFilter     值的过滤器

    用于测试列值,有CompareOp的枚举类型,可以测试等于,不等于或范围。不用FilterList的话scan设置的Filter就是最后设置的那个。

		Scan scan = new Scan();
		scan.setStartRow("row0".getBytes());
		scan.setStopRow("row9".getBytes());
		
		SingleColumnValueFilter scvf = new SingleColumnValueFilter(
				"f".getBytes(),"name".getBytes(), CompareOp.GREATER, "name2".getBytes());

scan.setFilter(scvf);

比较器:

1. RegexStringComparator

    支持值比较的正则表达式。

		Scan scan = new Scan();
		scan.setStartRow("row0".getBytes());
		scan.setStopRow("row
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值