lucene4.7 过滤Filter(六)
2016-03-10 16:05
169 查看
摘要 关于过滤方面的知识,也就是Filter,如果了解Solr的朋友们,肯定都会知道Solr里面fq这个参数,这个参数的作用其实就是lucene里面的过滤,对一些q参数查询的结果集,做过滤或者限制返回一些我们需要的内容,可以理解成缩小搜索空间的一种策略。
先介绍下查询与过滤的区别和联系,其实查询(各种Query)和过滤(各种Filter)之间非常相似,可以这样说只要用Query能完成的事,用过滤也都可以完成,它们之间可以相互转换,最大的区别就是使用过滤返回的结果集不带评分操作,而使用Query返回的结果都是带相关性评分的,所以当我们如果有一些跟评分操作没有关系的业务,优先使用Filter操作,将会获取更好的性能,其实这也是Solr里面的q参数跟fq参数的区别。
[b]下面,开始进入正题,在这之前,老生常谈的先来了解一下Lucene里面有关于Filter的整体知识
[/b]
[b]下面,我们来看下具体的在代码里怎么实现,先来看下我们的测试数据
[/b]
?
核心代码
?
输出结果
?
[b]核心代码 [/b]
?
输出结果
?
核心代码
?
输出结果
?
核心代码
?
输出结果
?
核心代码
?
输出结果
?
最后我来看下,如何继承Filter基类,来定制我们自己的filter,自定义的Filter,虽然某些时候,功能很强大灵活,但是有几个缺点,我们的了解1,保证是内容不重复的字段,例如主键,如果重复,默认返回第一个作为结果集显示2,保证不能被分词的内容,如果是分词的字段,则可能会出现一些不正确的结果。
自定义Filter类
?
测试查询代码
?
输出结果
?
自定义过滤器虽然有缺点,但是某些场景下却能发挥很灵活的作用,特别是对没有分词的字段进行过滤操作。
/article/2216235.html
先介绍下查询与过滤的区别和联系,其实查询(各种Query)和过滤(各种Filter)之间非常相似,可以这样说只要用Query能完成的事,用过滤也都可以完成,它们之间可以相互转换,最大的区别就是使用过滤返回的结果集不带评分操作,而使用Query返回的结果都是带相关性评分的,所以当我们如果有一些跟评分操作没有关系的业务,优先使用Filter操作,将会获取更好的性能,其实这也是Solr里面的q参数跟fq参数的区别。
[b]下面,开始进入正题,在这之前,老生常谈的先来了解一下Lucene里面有关于Filter的整体知识
[/b]
[b]下面,我们来看下具体的在代码里怎么实现,先来看下我们的测试数据
[/b]
?
?
?
?
?
?
?
?
?
?
?
自定义Filter类
?
?
?
/article/2216235.html
相关文章推荐
- robots协议
- 解决eclipse闪退的办法
- FTP错误列表
- elasticsearch的5种分片查询优先级
- Java图像处理库 Sanselan
- elasticsearch 插件
- RPC框架性能基本比较测试
- Grant: Postgresql 9.0 得到增强
- common,Google Guava,Guice
- jdk 版本差异之 DateFormat.getDateInstance()
- jmx rmi 穿越防火墙问题及jmxmp的替代方案
- TCP/IP三次握手与四次挥手
- JAVA线程池(ThreadPoolExecutor)源码分析
- spark rdd 转换过程
- Java SE1.6中的Synchronized Mark Word
- googleCollection map 定时清除数据
- struts2 源码分析 request ---设置setParameters 的值 二
- java.util.ConcurrentModificationException
- 堆排序Heap sort
- Java之JMX