PriexQuery前缀搜索
来源:互联网 发布:国密算法怎么调用 编辑:程序博客网 时间:2024/06/11 12:15
/*
* 这段代码写的是BooleanQuery布尔搜索
* 顾名思义就是布尔型查询。
* 布尔型,是由多个子句和子句间的布尔逻辑所组成的查询
* */
package query;
import java.io.IOException;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.TermQuery;
public class Query_Boolean {
public Query_Boolean(String INDEX_STORE){
try{
IndexWriter writer = new IndexWriter(INDEX_STORE, new StandardAnalyzer(), true);
writer.setUseCompoundFile(false);
//创建3个文档
Document doc1 = new Document();
Document doc2 = new Document();
Document doc3 = new Document();
Field f1 = new Field("bookname", "钢铁是怎样炼成的", Field.Store.YES, Field.Index.TOKENIZED);
Field f2 = new Field("bookname", "英雄儿女", Field.Store.YES, Field.Index.TOKENIZED);
Field f3 = new Field("bookname", "篱笆女人和狗", Field.Store.YES, Field.Index.TOKENIZED);
doc1.add(f1);
doc2.add(f2);
doc3.add(f3);
writer.addDocument(doc1);
writer.addDocument(doc2);
writer.addDocument(doc3);
writer.close();
IndexSearcher searcher = new IndexSearcher(INDEX_STORE);
//创建两个词条对象
Term t1 = new Term("bookname","女");
Term t2 = new Term("bookname","狗");
//创建2个TermQuery对象
TermQuery q1 = new TermQuery(t1);
TermQuery q2 = new TermQuery(t2);
//构建Boolean对象
BooleanQuery query = new BooleanQuery();
//将两个TermQuery加入到Boolea的子句中去,且关系均为必须满足
query.add(q1, BooleanClause.Occur.MUST);
query.add(q2, BooleanClause.Occur.MUST);
//打印查询结构
Hits hits =searcher.search(query);
for(int i = 0; i < hits.length(); i++){
System.out.println(hits.doc(i));
}
}catch(IOException e){
e.printStackTrace();
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Query_Boolean qb = new Query_Boolean("E:\\Lucene项目\\索引文件");
}
}
* 这段代码写的是BooleanQuery布尔搜索
* 顾名思义就是布尔型查询。
* 布尔型,是由多个子句和子句间的布尔逻辑所组成的查询
* */
package query;
import java.io.IOException;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.BooleanQuery;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.TermQuery;
public class Query_Boolean {
public Query_Boolean(String INDEX_STORE){
try{
IndexWriter writer = new IndexWriter(INDEX_STORE, new StandardAnalyzer(), true);
writer.setUseCompoundFile(false);
//创建3个文档
Document doc1 = new Document();
Document doc2 = new Document();
Document doc3 = new Document();
Field f1 = new Field("bookname", "钢铁是怎样炼成的", Field.Store.YES, Field.Index.TOKENIZED);
Field f2 = new Field("bookname", "英雄儿女", Field.Store.YES, Field.Index.TOKENIZED);
Field f3 = new Field("bookname", "篱笆女人和狗", Field.Store.YES, Field.Index.TOKENIZED);
doc1.add(f1);
doc2.add(f2);
doc3.add(f3);
writer.addDocument(doc1);
writer.addDocument(doc2);
writer.addDocument(doc3);
writer.close();
IndexSearcher searcher = new IndexSearcher(INDEX_STORE);
//创建两个词条对象
Term t1 = new Term("bookname","女");
Term t2 = new Term("bookname","狗");
//创建2个TermQuery对象
TermQuery q1 = new TermQuery(t1);
TermQuery q2 = new TermQuery(t2);
//构建Boolean对象
BooleanQuery query = new BooleanQuery();
//将两个TermQuery加入到Boolea的子句中去,且关系均为必须满足
query.add(q1, BooleanClause.Occur.MUST);
query.add(q2, BooleanClause.Occur.MUST);
//打印查询结构
Hits hits =searcher.search(query);
for(int i = 0; i < hits.length(); i++){
System.out.println(hits.doc(i));
}
}catch(IOException e){
e.printStackTrace();
}
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Query_Boolean qb = new Query_Boolean("E:\\Lucene项目\\索引文件");
}
}
0 0
- PriexQuery前缀搜索
- Lucene 4.4 基于前缀搜索
- 使用mongodb实现前缀搜索提示功能
- Elasticsearch-前缀、通配符、正则、模糊搜索详解
- 前缀
- 前缀
- hdu 4597 dp+前缀和+记忆化搜索
- Nodis - 前缀匹配、模糊搜索, 基于redis和node.js
- UVA 11732 "strcmp()" Anyone? 前缀树(Trie)+简单搜索
- codeforces 776C Molly's Chemicals(前缀和 二分搜索)
- UVALive2678 UVA1121 Subsequence【前缀和+二分搜索+尺取法】
- POJ3061 ZOJ3123 Subsequence【前缀和+二分搜索+尺取法】
- NUC1742 Subsequence【前缀和+二分搜索+尺取法】
- BZOJ 1048: [HAOI2007]分割矩阵 记忆化搜索,二维前缀和
- BZOJ 1224: [HNOI2002]彩票 搜索,上下界剪枝,前缀和优化
- 前缀表达式
- LOCK前缀
- 参数前缀
- 如何在Eclipse中配置Tomcat
- Web Socket Server的Python实现
- 一个简单的storyboard示例,其中关于添加navigation的部分可以学习,此前没用过
- http+json
- 文章标题
- PriexQuery前缀搜索
- HDU 4185 Oil Skimming(离散化 + 二分图匹配)
- Python 字符串操作
- C++标准转换运算符const_cast
- 回调函数
- NOJ 网络赛 D题 天神小学
- 用USBwriter往优盘写入.iso文件后,优盘无法格式化
- 通过WIFI进行Android调试
- 漫道短信 联通电信收不到的处理方法