牛到小试一下 lucene 入门记录
set1 : 当然是引入lucene jar包了, 在这个ant, maven大行其道的时代,毫不犹豫的选择了maven。
<dependency>
<groupId>org.apache.lucene</groupId>
<artifactId>lucene-core</artifactId>
<version>3.6.0</version>
</dependency>
set2:建立索引
定义一个简单的接口: public CargoIndexActionResult create();
实现:
IndexWriter writer = getWriter();
writer.setInfoStream(System.out);
Document doc = null;
for (CargoDO cargo : cargoes) {
doc = new Document();
IndexConvertor.convert(doc, cargo);
writer.addDocument(doc);
}
writer.close();
directory.close();
set3:搜索
@Override
@SuppressWarnings("deprecation")
public SearchCargoPageListResult search(CarogoSearchOrder order) {
SearchCargoPageListResult result = new SearchCargoPageListResult(order.getCurrentPage(),
order.getPageSize());
Directory directory;
try {
directory = getDirectory();
IndexSearcher searcher = new IndexSearcher(directory); //B
QueryParser parser = new QueryParser(Version.LUCENE_36, "name", new SimpleAnalyzer());
Query query = parser.parse(order.getName());
TopScoreDocCollector topCollector = TopScoreDocCollector.create(100, false);
searcher.search(query, topCollector);
ScoreDoc[] docs = topCollector.topDocs((order.getCurrentPage() - 1)
* order.getPageSize()).scoreDocs;
if (null == docs) {
result.setResultCode(SearchResultEnum.HAVE_NOT_DATA_EXCEPTION);
} else {
result.setTotalItems(topCollector.getTotalHits());
List<CargoInfo> cargos = new ArrayList<CargoInfo>();
Document doc = null;
CargoInfo info = null;
for (ScoreDoc scoreDoc : docs) {
int sn = scoreDoc.doc;
doc = searcher.doc(sn);
info = new CargoInfo();
SearchConvertor.convert(info, doc);
cargos.add(info);
}
searcher.close();
directory.close();
setSuccessResult(result);
}
} catch (ParseException e) {
logger.error("", e);
} catch (IOException e) {
logger.error("", e);
}
return result;
}
分享到:
相关推荐
Lucene入门与使用,非常简单,适合入门
`lucene入门小实例.txt` 文件中可能包含了一个简单的Lucene使用示例,例如: 1. 创建 `Directory` 对象,比如使用 `FSDirectory.open()` 打开一个文件系统的目录来存储索引。 2. 实例化 `Analyzer`,如使用 `...
这个“lucene入门小例子”很可能是为了帮助初学者理解并掌握Lucene的基本用法而设计的一系列示例代码。 Lucene的核心概念包括索引、文档、字段和查询。首先,你需要理解索引的概念,它类似于传统数据库中的索引,但...
以上是Lucene入门的基本知识和关键概念,通过深入学习和实践,你可以掌握如何利用Lucene构建强大的全文搜索引擎。记住,实践中遇到的问题往往是最好的学习资源,不断尝试和解决,你将逐渐成为Lucene的专家。
**Lucene 3.6 入门案例** Lucene 是一个高性能、全文本搜索库,由 Apache 软件基金会开发。它提供了完整的搜索功能,包括索引、查询、评分等,广泛应用于各种项目和产品中。在这个入门案例中,我们将深入理解如何...
**Lucene入门学习文档** **一、什么是Lucene** Lucene是Apache软件基金会下的一个开源全文检索库,它提供了一个高性能、可扩展的信息检索服务。Lucene最初由Doug Cutting开发,现在已经成为Java社区中事实上的标准...
**Lucene 入门教程** Lucene 是一个高性能、全文本搜索库,由 Apache 软件基金会开发。...通过实践“Lucene入门demo”,你可以亲手创建并测试一个简单的 Lucene 搜索应用,进一步加深对 Lucene 工作原理的理解。
【Lucene】Lucene入门心得 Lucene是一个高性能、全文本搜索库,由Apache软件基金会开发,被广泛应用于各种搜索引擎的构建。它提供了一个简单的API,使得开发者可以方便地在自己的应用程序中集成全文检索功能。...
**全文搜索引擎Lucene入门** 全文搜索引擎Lucene是Apache软件基金会的一个开放源代码项目,它为Java开发者提供了一个高性能、可扩展的信息检索库。Lucene以其强大的文本搜索功能和高效的索引能力,在各种需要全文...
《Lucene入门到项目开发》 Lucene是一个高性能、全文本搜索库,由Apache软件基金会开发,被广泛应用于各种搜索引擎的构建。它提供了一个简单但功能强大的API,可以帮助开发者快速实现对文本数据的检索和分析。 一...
**Lucene 入门指南** Lucene 是一个高性能、全文本搜索库,由 Apache 软件基金会开发并维护。它是 Java 开发人员用来构建搜索引擎应用程序的基础工具。本指南将帮助初学者理解 Lucene 的核心概念,以及如何利用它来...
1. **Compass**:提供了一个高级的、面向对象的API,简化了Lucene的使用。 2. **Nutch**:是一个开源的Web搜索引擎,基于Lucene构建,用于大规模网络爬虫和搜索。 3. **开源搜索引擎列表**:包括许多其他基于Lucene...
**标题:“Lucene-入门”** Lucene是一个高性能、全文本搜索库,由Apache软件基金会开发并维护。它是Java编写的一个开源项目,被广泛应用于构建搜索引擎或者在大型数据集上进行全文检索。Lucene提供了丰富的搜索...
在这个经典Lucene入门模块中,我们将深入理解如何使用Lucene进行索引创建和搜索操作。 首先,我们来看Lucene如何建立数据的索引。这通常涉及以下几个步骤: 1. **索引创建**:使用 `IndexWriter` 对象来创建或更新...
### Lucene 入门基础教程知识点详解 #### 一、Lucene简介 - **定义**:Lucene是一款高性能、全功能的文本搜索引擎库,由Java编写而成,属于Apache项目的一部分。 - **适用场景**:适合于任何需要进行全文检索的应用...
1. **分词**: 分词是搜索引擎的第一步,它将输入的文本拆分成可搜索的词语。Lucene.Net提供了Analyzer类来完成这个任务,开发者可以根据需求自定义分词规则,比如使用标准分词器(StandardAnalyzer)或中文分词器...