Lucene:QueryParser
作为lucene的Query工具,QueryParser却是最重要的一个。简单的说,QueryParser能够根据用户的输入来进行解析,自动构建合适的Query对象。下面简单总结一下它的实现:
目录
- 用户输入
- QueryParser的初始化
- 短语和QueryParser
- QueryParser的模糊匹配查询
- 通配符与QueryParser
- QueryParser指定Field查询
- QueryParser的范围RangeQuery查询
- QueryParser的多域MultiFieldQueryParser查询
1、用户输入(词条的定义)
当用户输入要查询的关键字串后,QueryParser首先会对其进行解析,而这种解析是以词条为基础的。而词条和词条之间呢,则是用空格分开的。
2、QueryParser的初始化
逻辑运算符“AND,OR,NOT”

1 String field = “bookname”;//设置一个默认的field
2 String queryStr = “Persist Google”;//用户输入的关键字
3
4
5 //new了一个QueryParser,并且传进去两个参数。
6 //第一个参数是默认要检索的field;(因为在用户没有指定field时,lucene会在默认的field中检索)
7 //第二个参数是用到的分析器;(注意:这里的分析器一定要使用建立索引时的分析器,否则所分词条与索引中的内容不一致,最终导致错误出现!)
8
9 QueryParser parser = new QueryParser(field,new StandardAnalyzer());
10
11 Query q = parser.parser(queryStr);//执行QueryParser的parser方法

在这里,我们(用户)所输入的“Persist Google”被QueryParser分析成了“OR”的关系,即检索有“Persist”或者“Google”的文档。这并非我们的意愿,我们要查的是同时含有“Persist”和“Google”文档。那么我们尝试改变一下QueryParser默认的布尔逻辑。
1 //上面的代码中只需要加上下面语句即可实现。
2 parser.setDefaultOperator(QueryParser.AND_OPERATOR);
或者,将用户输入的关键字串“Persist Google”改为“Persist AND Google”也可以实现上述要求。
3、短语和QueryParser
我们输入几个词,QueryParser就会把它解成几个词条。那么当我们输入一句话的时候,(如:Rome is not built in one day)此时这句话有七个词,我们并不想把它分成几个词来查询,怎么办呢?当然,lucene的开发者早已经想到了这点,也很人性化的解决了这一个问题,他们说:“给这句话加个引号吧!”。
1 //我们则只需要将代码
2 String queryStr = “Rome is not built in one day”;
3
4 //改为如下代码即可。
5 String queryStr = “/"Rome is not built in one day/””;
4、QueryParser的模糊匹配查询
FuzzyQuery(即模糊匹配)查询。它的用法与其他Query对象却是大同小异的。不同的是,FuzzyQuery有一个相似度的概念。我们不需要深刻理解,只需要知道它会去匹配和输入词条相似的其他词条即可。
1 //如:FuzzyQuery默认的相似度为0.5
2 Term t = new Term(“bookname”, “work”);
3 FuzzyQuery query = new FuzzyQuery(t);
用QueryParser的概念对输入关键字进行分析,我们只需要给输入的关键字加一个符号。如:work~0.2,即把work相似度0.5改为了0.2
5、通配符与QueryParser

1 //在之前的Google中提到的通配符原理亦是如此。
2 Term t = new Term(“bookname”, “wor?”);
3 WildcardQuery q = new WildcardQuery(t);
4
5 //wor?可以被QueryParser识别,表示前三个字母为wor的词条。
6 //即有可能是word,work...

6、QueryParser指定Field查询
1 //此时回去检索发布时间为2010-12-5的所有文档,并且bookname为work
2 String queryStr = “work publishdate:2010-12-5”;
3 QueryParser parser = new QueryParser(“bookname”,new StandardAnalyzer());
4 Parser.setDefaultOperator(QueryParser.AND_OPERATOR);
5 Query query = parser.parser(queryStr);
7、QueryParser的范围查找(RangeQuery):TO
1 //找出发布日期从2010-12-01到2010-12-05的所有文档
2 String queryStr = “[2010-12-1 TO 2010-12-5]”;
3 QueryParser parser = new QueryParser(“bookname”,new StandardAnalyzer());
4 Parser.setDefaultOperator(QueryParser.AND_OPERATOR);
5 Query query = parser.parser(queryStr);
8、QueryParser的多域查询MultiFieldQueryParser

1 //如查询多个域, title和content, 要定义一个包含多域的数组
2 String[] fields = {"title","content"};
3 String queryStr=“计算机”
4 QueryParser queryParser = new MultiFieldQueryParser(Version.LUCENE_36, fields, new StandardAnalyzer());
5 Query query = queryParser.parse(queryStr);

在Lucene中,还有很多搜索方式,如:多索引搜索MultiSearcher,多线程搜索ParalellMultiSearcher等。用法都基本类似,原理也大同小异,是比较好理解的。
值得关注的是多线程搜索ParalellMultiSearcher,因为若只有单个线程的话,多访问时,总要等上个线程结束,这样反馈时间是很慢的,这里就需要多线程搜索来提高效率。
以上所提到的所有方法都可以互相结合或者嵌套使用,对各种口味的用户都能给予满足,这也正是Lucene的灵活性。
Lucene:QueryParser的更多相关文章
- Lucene:基于Java的全文检索引擎简介
Lucene:基于Java的全文检索引擎简介 Lucene是一个基于Java的全文索引工具包. 基于Java的全文索引/检索引擎--Lucene Lucene不是一个完整的全文索引应用,而是是一个用J ...
- Lucene:基于Java的全文检索引擎简介 (zhuan)
http://www.chedong.com/tech/lucene.html ********************************************** Lucene是一个基于Ja ...
- 黑马_10 Lucene:全文检索
10 Lucene:01.全文检索基本介绍 10 Lucene:02.创建索引库和查询索引 10 Lucene:03.中文分析器 10 Lucene:04.索引库维护CURD
- Lucene:信息检索与全文检索
目录 信息检索的概念 信息检索技术的分类 全文检索与数据库查询对比 全文检索工具一般由三部分构成 全文检索中建立索引和进行检索的流程 索引里面究竟存什么 如何创建索引 如何对索引进行检索 Lucene ...
- Lucene系列六:Lucene搜索详解(Lucene搜索流程详解、搜索核心API详解、基本查询详解、QueryParser详解)
一.搜索流程详解 1. 先看一下Lucene的架构图 由图可知搜索的过程如下: 用户输入搜索的关键字.对关键字进行分词.根据分词结果去索引库里面找到对应的文章id.根据文章id找到对应的文章 2. L ...
- lucene.net 使用过程中的 几个注意事项(含termquery 和QueryParser 的区别)
几个注意事项1.建立索引时 插入的顺序(不设置document和字段的boost) 会影响到 查询结果的默认排序,建议:将最新生成的文章 最后建索引 这样 查询结果首先显示的是 最后插入的数据2.Bo ...
- Lucene学习笔记: 五,Lucene搜索过程解析
一.Lucene搜索过程总论 搜索的过程总的来说就是将词典及倒排表信息从索引中读出来,根据用户输入的查询语句合并倒排表,得到结果文档集并对文档进行打分的过程. 其可用如下图示: 总共包括以下几个过程: ...
- lucene学习笔记:二,Lucene的框架
Lucene总的来说是: 一个高效的,可扩展的,全文检索库. 全部用Java实现,无须配置. 仅支持纯文本文件的索引(Indexing)和搜索(Search). 不负责由其他格式的文件抽取纯文本文件, ...
- Lucene学习总结之七:Lucene搜索过程解析
一.Lucene搜索过程总论 搜索的过程总的来说就是将词典及倒排表信息从索引中读出来,根据用户输入的查询语句合并倒排表,得到结果文档集并对文档进行打分的过程. 其可用如下图示: 总共包括以下几个过程: ...
随机推荐
- Python:函数定义
#!/usr/bin/python3 #函数 def add(a,b): return a+b print("add(2,5) = ",add(2,5)) def add2(a,b ...
- underscorejs-sample学习
2.22 sample 2.22.1 语法: _.sample(list, [n]) 2.22.2 说明: 从list中产生一个随机样本.传参n后返回n个随机元素,各元素不重复. 2.22.3 代码示 ...
- phpcms V9利用num++实现多样形式列表标签调用
在首页或者频道页调用文章列表的时候,经常会使用到左右对称或者每五行出现一条横线的调用形式. 其实代码很简单,利用num++的循环方式,以及{if}{/if}进行样式判断即可.代码如下: {pc:con ...
- css编译工具Sass中混合宏,继承,占位符分别在什么时候使用
//SCSS中混合宏使用 @mixin mt($var){ margin-top: $var; } .block { @include mt(5px); span { display:block; @ ...
- mvc的真实含义
MVC是一个设计模式,它强制性的使应用程序的输入.处理和输出分开.使用 MVC应用程序被分成三个核心部件:模型(M).视图(V).控制器(C),它们各自处理自己的任务. 视图 : 视图是用户看到并与之 ...
- [BZOJ 3238] [AHOI 2013] 差异 【后缀数组 + 单调栈】
题目链接:BZOJ - 3238 题目分析 显然,这道题就是求任意两个后缀之间的LCP的和,这与后缀数组的联系十分明显. 求出后缀数组后,求出字典序相邻两个后缀的LCP,即 Height 数组. 那么 ...
- Networking
poj1287:http://poj.org/problem?id=1287 题意:平面上有许多点,又有许多边.每条边有一定的长度,且只会连接两个不同的点.现需要从这些边中选择某些边,使得尽可能多的点 ...
- ibatis动态语句加and 和不加and
<select id="queryGoodsGroupCodeName" parameterClass="String" resultClass=&quo ...
- C++ STL的各种实现版本
ANSI/ISO的C++ STL规范版本正式通过以后,各个C++编译器厂商就可以依照标准所描述的原型去实现C++ STL泛型库,于是出现多种符合标准接口,但具体实现代码不同的泛型库,主要有: HP S ...
- 【HDOJ】3309 Roll The Cube
BFS,考虑一球进洞仅一球滚动以及两球重叠的情况即可. /* 3309 */ #include <iostream> #include <queue> #include < ...