lucene 部分更新,实例

    import java.io.IOException;
    import java.nio.file.Paths;
    import java.util.ArrayList;
    import java.util.List;
    
    import org.apache.lucene.index.IndexReader;
    import org.apache.lucene.analysis.cn.smart.SmartChineseAnalyzer;
    import org.apache.lucene.document.Document;
    import org.apache.lucene.document.Field;
    import org.apache.lucene.document.TextField;
    import org.apache.lucene.index.DirectoryReader;
    import org.apache.lucene.index.IndexWriter;
    import org.apache.lucene.index.IndexWriterConfig;
    import org.apache.lucene.index.IndexWriterConfig.OpenMode;
    import org.apache.lucene.index.Term;
    import org.apache.lucene.queryparser.classic.MultiFieldQueryParser;
    import org.apache.lucene.queryparser.classic.ParseException;
    import org.apache.lucene.search.BooleanClause.Occur;
    import org.apache.lucene.search.IndexSearcher;
    import org.apache.lucene.search.Query;
    import org.apache.lucene.search.ScoreDoc;
    import org.apache.lucene.search.TopDocs;
    import org.apache.lucene.search.similarities.BM25Similarity;
    import org.apache.lucene.store.FSDirectory;
    import org.apache.lucene.store.IOContext;
    import org.apache.lucene.store.RAMDirectory;
    
    public class Example2 {
    
        public static IndexWriter writer;
        public static RAMDirectory idxDir;
        public static SmartChineseAnalyzer analyzer;
    
        public static void makeIndex() throws IOException {
    
            FSDirectory fsDir = FSDirectory.open(Paths.get("C:\\Users\\gt\\Desktop\\_ROKID_\\fast-sent-match\\example"));
            idxDir = new RAMDirectory(fsDir, IOContext.DEFAULT);
            analyzer = new SmartChineseAnalyzer();
            IndexWriterConfig iwc = new IndexWriterConfig(analyzer);
            iwc.setSimilarity(new BM25Similarity());
    
            iwc.setOpenMode(OpenMode.CREATE_OR_APPEND);
            writer = new IndexWriter(idxDir, iwc);
    
            List<String> listSent = new ArrayList<String>();
            listSent.add("金古江湖是最好玩的金庸游戏1");
            listSent.add("金古江湖是最好玩的金庸游戏2");
            int id = 0;
            for (String sent : listSent) {
                id++;
                Document doc = new Document();
                doc.add(new TextField("questionType", "A", Field.Store.YES));
                doc.add(new TextField("questionId", String.valueOf(id), Field.Store.YES));
                doc.add(new TextField("question", sent.trim(), Field.Store.YES));
                writer.addDocument(doc);
            }
            
            List<String> listSent2 = new ArrayList<String>();
            listSent2.add("金古江湖是最好玩的金庸游戏3");
            for (String sent : listSent2) {
                Document doc = new Document();
                doc.add(new TextField("questionType", "A", Field.Store.YES));
                doc.add(new TextField("questionId", String.valueOf(1), Field.Store.YES));
                doc.add(new TextField("question", sent.trim(), Field.Store.YES));
                writer.updateDocument(new Term("questionId", "1"), doc);
            }
            writer.commit();
            writer.close();
        }
    
        public static void main(String[] args) throws IOException, ParseException {
            makeIndex();
    
            String[] stringQuery = { "A", "1", "金古江湖" };
            String[] fields = { "questionType", "questionId", "question" };
            Occur[] occ = { Occur.MUST, Occur.SHOULD, Occur.MUST };
            Query query = MultiFieldQueryParser.parse(stringQuery, fields, occ, analyzer);
    
            TopDocs results = null;
            IndexReader reader = DirectoryReader.open(idxDir);
            IndexSearcher searcher = new IndexSearcher(reader);
            results = searcher.search(query, 5);
            ScoreDoc[] hits = results.scoreDocs;
            for (int i = 0; i < hits.length; ++i) {
                Document doc = searcher.doc(hits[i].doc);
                String strDocSent = doc.get("question");
                System.out.println(strDocSent);
            }
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
Lucene是一个开源的全文搜索引擎库,它提供了丰富的API和功能来创建、更新和搜索索引。要更新Lucene索引,首先需要获取一个IndexWriter实例,然后通过该实例来执行索引更新操作。 更新索引的过程通常包括以下几个步骤: 1. 创建或获取一个IndexWriter实例:IndexWriter负责索引的写入和更新操作,需要确保只有一个线程能够同时操作一个IndexWriter实例。 2. 创建或获取文档对象:更新索引需要构建文档对象,可以通过Document类来创建一个文档对象,并向其添加字段。 3. 执行更新操作:可以通过IndexWriter的addDocument、updateDocument或deleteDocuments方法来执行索引的添加、更新或删除操作。 4. 提交更新:在更新索引操作完成后,需要调用IndexWriter的commit或flush方法来提交更新,使更新操作生效。 更新索引的频率取决于应用的需求,可以是实时更新,也可以是批量更新。总之,更新索引是一个重要的操作,在使用Lucene构建搜索引擎或全文检索功能时,需要根据具体的业务需求来合理地更新索引。同时,为了保证索引更新的性能和可靠性,需要注意合理地管理IndexWriter实例,确保其在适当的时候被关闭或重新打开。 总之,通过Lucene的API和功能,可以方便地进行索引的更新操作,从而保证应用的搜索功能能够及时、准确地返回符合用户需求的搜索结果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

热爱Coding

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值