lucene入门代码三(near-real-time)

一个简单的接近实时搜索的例子源自(Lucene in aiction)

package com.yale.lucene;

import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.TermQuery;
import org.apache.lucene.search.TopDocs;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.RAMDirectory;
import org.apache.lucene.util.Version;

/**
*
* 接近实时搜索
*
*/
public class NearRealTimeTest
{
public static void main(String[] args) throws Exception
{
// Create RAMDirectory
Directory dir = new RAMDirectory();
IndexWriter writer = new IndexWriter(dir, new StandardAnalyzer(
Version.LUCENE_30), IndexWriter.MaxFieldLength.UNLIMITED);
for(int i =0;i<10;i++){
Document doc = new Document();
doc.add(new Field("id",""+i,Field.Store.NO,Field.Index.NOT_ANALYZED_NO_NORMS));
doc.add(new Field("text","aaa",Field.Store.NO,Field.Index.ANALYZED));
writer.addDocument(doc);
}
//Create near-real-time reader
IndexReader reader = writer.getReader();
//Warp reader in IndexSearcher
IndexSearcher searcher = new IndexSearcher(reader);

Query query = new TermQuery(new Term("text","aaa"));

TopDocs docs = searcher.search(query,1);
//Search returns 10 hits
System.out.println("匹配结果:"+docs.totalHits+"次");
//delete 1 document
writer.deleteDocuments(new Term("id","7"));
//add 1 document
Document doc = new Document();
doc.add(new Field("id","11",Field.Store.NO,Field.Index.NOT_ANALYZED_NO_NORMS));
doc.add(new Field("text","bbb",Field.Store.NO,Field.Index.ANALYZED));
writer.addDocument(doc);
//Reopen reader
IndexReader newReader = reader.reopen();
//Confirm reader is new
System.out.println(reader==newReader);
reader.close();
searcher = new IndexSearcher(newReader);
TopDocs hits = searcher.search(query,10);
//Search returns 9 hits
System.out.println("匹配结果:"+hits.totalHits+"次");
query = new TermQuery(new Term("text", "bbb"));
hits = searcher.search(query, 1);
//Search returns 1 hits
System.out.println("匹配结果:"+hits.totalHits+"次");
newReader.close();
writer.close();

}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值