索引已经建立,但就是检索不到数据。hits.length()一直为0
public Hits search(String queryString) {
Hits hits = null;
try {
File file = new File(indexPath);
Directory directory = FSDirectory.getDirectory(file);
IndexSearcher searcher = new IndexSearcher(directory);
String[] fields = { "CUSTOMERID", "SHIPNAME", "SHIPCITY",
"SHIPCOUNTRY" };
MultiFieldQueryParser mQueryPaser = new MultiFieldQueryParser(
fields, getAnalyzer());
Query query = mQueryPaser.parse(queryString);
hits = searcher.search(query);
} catch (Exception e) {
//do something here
}
return hits;
}
public void doIndex(String sql) {
try {
IndexWriter writer = new IndexWriter(indexPath, getAnalyzer(), true);
ResultSet rs = luceneDB.getResult(sql);
while (rs.next()) {
Document doc = new Document();
doc.add(new Field("CUSTOMERID", rs.getString("CUSTOMERID"),
Field.Store.YES, Field.Index.TOKENIZED));
doc.add(new Field("SHIPNAME", rs.getString("SHIPNAME"),
Field.Store.YES, Field.Index.TOKENIZED));
doc.add(new Field("SHIPCITY", rs.getString("SHIPCITY"),
Field.Store.YES, Field.Index.TOKENIZED));
doc.add(new Field("SHIPCOUNTRY", rs.getString("SHIPCOUNTRY"),
Field.Store.YES, Field.Index.TOKENIZED));
writer.addDocument(doc);
}
writer.optimize();
writer.close();
} catch (CorruptIndexException ce) {
System.out.println(ce.getMessage());
} catch (IOException ie) {
System.out.println(ie.getMessage());
} catch (SQLException se) {
System.out.println(se.getMessage());
}
}
public Analyzer getAnalyzer() {
return new StandardAnalyzer();
}
分享到:
- 2007-08-22 10:27
- 浏览 921
- 评论(4)
- 论坛回复 / 浏览 (4 / 3031)
- 查看更多
相关推荐
### Lucene实现过程中存在的问题及解决方式 #### 一、Lucene简介与应用场景 Lucene是一款高性能、全功能的文本搜索引擎库,它被广泛应用于各种需要进行高效全文检索的应用场景中,例如网站搜索、文档管理等。由于...
lucene,lucene教程,lucene讲解。 为了对文档进行索引,Lucene 提供了五个基础的类 public class IndexWriter org.apache.lucene.index.IndexWriter public abstract class Directory org.apache.lucene.store....
在使用Lucene时,可能会遇到字符编码问题,这通常是由于不同系统或程序之间处理字符集的方式不一致导致的。下面将详细探讨Lucene中的字符编码问题及其解决方案。 首先,我们要理解什么是字符编码。字符编码是将字符...
lucene3.0 lucene3.0 lucene3.0 lucene3.0 lucene3.0
使用这些JAR包时,开发者需要根据具体需求选择合适的模块,并确保它们的版本一致,以避免潜在的兼容性问题。同时,还需要正确配置分词器,以适应所处理的文本内容。此外,对于大型应用,可能还需要结合Solr或Elastic...
这通常涉及使用词库和自动切分词算法来处理中文的分词问题。 **应用场景** 许多知名的 Java 项目都采用了 Lucene 作为其全文检索引擎,例如 Jive(Web 论坛系统)、Eyebrows(邮件列表归档系统)、Cocoon(基于 ...
本压缩包包含的是Lucene 3.5.0版本的全部源码,对于想要深入理解Lucene工作原理、进行二次开发或者进行搜索引擎相关研究的开发者来说,是一份非常宝贵的学习资源。 Lucene 3.5.0是Lucene的一个重要版本,它在3.x...
《Lucene in Action》是关于Apache Lucene的权威指南,这本书深入浅出地介绍了全文搜索引擎的构建和优化。Lucene是一个高性能、全文本搜索库,它允许开发人员在应用程序中轻松实现复杂的搜索功能。这本书主要面向...
Lucene是一款强大的全文搜索引擎库,广泛应用于各种数据检索场景。在C#环境下,利用Lucene进行时间区间搜索是提高数据检索效率和精确度的重要手段。本篇将深入探讨如何在C#中实现Lucene的时间区间查询匹配,以及涉及...
《Annotated Lucene 中文版 Lucene源码剖析》是一本深入探讨Apache Lucene的书籍,专注于源码解析,帮助读者理解这个强大的全文搜索引擎库的工作原理。Lucene是一款开源的Java库,它提供了高效的文本搜索功能,被...
**Lucene 4.0.0 全文检索引擎工具包** Apache Lucene 是一个高度成熟、广泛使用的开源全文检索库,由Java编写。作为一款搜索引擎工具包,它提供了核心的索引和搜索功能,使得开发者能够快速地在应用程序中集成强大...
`ik-analyzer-4.9.0.jar`是Ik分词器的对应版本,它包含了一系列的分词规则和优化策略,可以很好地处理中文的停用词、词语歧义等问题。 五、使用与配置 在实际项目中,开发者需要根据具体需求选择和配置合适的...
在IT领域,搜索引擎技术是至关重要的,而Lucene作为一个开源全文搜索引擎库,广泛应用于各种文本检索系统中。本文将深入探讨Lucene示例中的BM25相似度计算,旨在帮助初学者理解如何利用Lucene 4.7.1版本构建索引、...
**Lucene 2.0 API 和 Lucene 3.0 API 深度解析** Lucene 是一个由 Apache 软件基金会开发的全文搜索引擎库,它为开发者提供了在 Java 应用程序中实现高性能、可扩展的全文搜索功能的能力。Lucene 的 API 设计得相当...
因此,在构建项目时,需要确保所有依赖项都已正确解决,避免版本冲突问题。此外,对于特定的语言处理或特殊需求,可能还需要额外下载和引入其他分析器或其他特定功能的jar包。 总的来说,Lucene 5.0.0的这些jar文件...
通过深入研究《Lucene in Action》的源码,开发者不仅可以理解Lucene的基本工作原理,还能学习如何实际应用这些知识,解决具体的搜索问题。对于初学者而言,这是一个很好的起点,可以帮助他们快速上手并逐步掌握全文...
**Lucene原理详解** Lucene是一个高性能、全文检索库,由Apache软件基金会开发并维护,是Java编程语言中广泛使用的搜索引擎库。它提供了一个简单但功能强大的API,用于索引和搜索文本数据,使得开发者可以轻松地在...
Lucene 5.x版本相对于3.6.0有显著的改进,不仅优化了API设计,提高了性能,还修复了许多已知问题。开发者在升级到新版本时,需要注意API的变更,以避免兼容性问题,并充分利用新版本带来的优势。通过理解这些变化,...
使用Lucene时,你可能需要考虑如何处理中文分词、如何优化搜索性能、如何实现多语言支持等问题。此外,对于大型数据集,可能需要了解如何分布式部署和管理索引。 总结来说,Lucene是一个强大的全文检索引擎,通过...