在应用中加入全文检索功能
&(EHq ——基于Java的全文索引引擎Lucene简介
,apNwkY 作者: 车东 Email: chedongATbigfoot.com/chedongATchedong.com
+ WVIZZ8 z-dFDtiA 写于:2002/08 最后更新: 11/29/2006 17:23:30
M|q~6oM Feed Back >> (Read this before you ask question)
-(i(02PX ]mQw,S)/" 版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明
!gF9k8\Yr$ http://www.chedong.com/tech/lucene.html y}FZD?" {%C*{,#+8q 关键词:Lucene java full-text search engine Chinese word segment
fmfTSN(Q~` !M7<BD}; 内容摘要:
%@Oma <F;v`h|+S Lucene是一个基于Java的全文索引工具包。
ZE?f!ifp ljC(L/I 基于Java的全文索引引擎Lucene简介:关于作者和Lucene的历史
lhH`dG D 全文检索的实现:Luene全文索引和数据库索引的比较
z0%\OhuCcf 中文切分词机制简介:基于词库和自动切分词算法的比较
'm3t|:nMU 具体的安装和使用简介:系统结构介绍和演示
MP^ d}FL Hacking Lucene:简化的查询分析器,删除的实现,定制的排序,应用接口的扩展
,HB2hHD 从Lucene我们还可以学到什么
T f4tj!t- 基于Java的全文索引/检索引擎——Lucene
8j5<6Cv_
R'}95S< Lucene不是一个完整的全文索引应用,而是是一个用Java写的全文索引引擎工具包,它可以方便的嵌入到各种应用中实现针对应用的全文索引/
J-xS:Ha'l %zBCq"y 检索功能。
WOLuw% z'7[T ie Lucene的作者:Lucene的贡献者Doug Cutting是一位资深全文索引/检索专家,曾经是V-Twin搜索引擎(Apple的Copland操作系统的成就之一)的
~g#r6pzN- $P z`$~ 主要开发者,后在Excite担任高级系统架构设计师,目前从事于一些INTERNET底层架构的研究。他贡献出的Lucene的目标是为各种中小型应用
>j*;vG5T ^T5X)Nu{=C 程序加入全文检索功能。
dY7'OAUyVl @I`C#~ Lucene的发展历程:早先发布在作者自己的
www.lucene.com,后来发布在SourceForge,2001年年底成为APACHE基金会jakarta的一个子项目:
bWWXc[O2&( 5cJ!" http://jakarta.apache.org/lucene/ ({s6eqMhDd *\}}Bv+9 已经有很多Java项目都使用了Lucene作为其后台的全文索引引擎,比较著名的有:
{q%Sx*k9[ #KxbM-1= Jive:WEB论坛系统;
h!rM^ Eyebrows:邮件列表HTML归档/浏览/查询系统,本文的主要参考文档“TheLucene search engine: Powerful, flexible, and free”作者就是
*&BnF\?m B* kcNlW EyeBrows系统的主要开发者之一,而EyeBrows已经成为目前APACHE项目的主要邮件列表归档系统。
;-P)m Cocoon:基于XML的web发布框架,全文检索部分使用了Lucene
dCyqvg6u Eclipse:基于Java的开放开发平台,帮助部分的全文索引使用了Lucene
v+7kU= !Ucjax~ 对于中文用户来说,最关心的问题是其是否支持中文的全文检索。但通过后面对于Lucene的结构的介绍,你会了解到由于Lucene良好架构设计
IW=cym7 gTl<wo + ,对中文的支持只需对其语言词法分析接口进行扩展就能实现对中文检索的支持。
ncu`vYI. e^p
+1-B 全文检索的实现机制
W>_]dPB S/ j#r6b]k(Hv Lucene的API接口设计的比较通用,输入输出结构都很像数据库的表==>记录==>字段,所以很多传统的应用的文件、数据库等都可以比较方便的
sUZX
} }KUd7[s 映射到Lucene的存储结构/接口中。总体上看:可以先把Lucene当成一个支持全文索引的数据库系统。
Hnknly :Z`:nq.a 比较一下Lucene和数据库:
m!<i0thJ 1"Z@Q`} Lucene 数据库
x:-.+C% 索引数据源:doc(field1,field2...) doc(field1,field2...) \ indexer / _____________
**9x?s S/|,u`g- | Lucene Index| -------------- / searcher \ 结果输出:Hits(doc(field1,field2) doc
O[tvR:Nh 1b=lpw1} (field1...))
0a8/B>
索引数据源:record(field1,field2...) record(field1..) \ SQL: insert/ _____________
H]Hv;fcC theZ]5_C | DB Index | ------------- / SQL: select \结果输出:results(record(field1,field2..) record
XL#[%X9 infl. (field1...))
^`un'5Vk #/PA A Document:一个需要进行索引的“单元”
_zlqtO 一个Document由多个字段组成 Record:记录,包含多个字段
]7-&V-Ct* Field:字段 Field:字段
HhO".GA Hits:查询结果集,由匹配的Document组成 RecordSet:查询结果集,由多个Record组成
" \I4u{zC g^*<f8 ~d 全文检索 ≠ like "%keyword%"
z/i+EE f{SB1M 通常比较厚的书籍后面常常附关键词索引表(比如:北京:12, 34页,上海:3,77页……),它能够帮助读者比较快地找到相关内容的页码。
d%l{V6 ),%6V5a+E 而数据库索引能够大大提高查询的速度原理也是一样,想像一下通过书后面的索引查找的速度要比一页一页地翻内容高多少倍……而索引之所
s4&^D< 74!oe u.> 以效率高,另外一个原因是它是排好序的。对于检索系统来说核心是一个排序问题。
$w"$r$K9K Gy=B&bo