Lucene中的域选项
2024-10-21 14:30:53
Field类是lucene在索引过程中的一个很重要的类,该类控制着域值被索引的方式
域选项主要包括以下几种选项:域索引选项、域存储选项、域的项向量选项、域的排序选项等
域索引选项:通过倒排索引来控制域值是否能够被搜索
Index.ANALYZED,将文本域分析成为一个或多个独立的语汇单元,每个语汇单元都能够被搜索
Index.NOT_ANALYZED,对文本域进行索引但是不进行分词(适用于对人名,URL,电话号码等需要进行精确匹配的搜索)
Index.ANALYZED_NO_NORMS 和Index.ANALYZED相似,但是不存储索引时的加权信息(相对来说节省内存)
Index.NOT_ANALYZED_NO_NORMS 和Index.NOT_ANALYZED相似但是不存储索引时的加权信息
Index.NO 使对应的域不能够被搜索
域存储选项:确定是否存储域的真实值,以便在搜索的时候进行恢复
Stroe.YES 指定存储域值(web页面的URL,数据库的ID,文章标题等可以进行存储)
Store.NO 不存储域值
项向量选项:可以实现类似查找同义词的这种功能(后边文章详细介绍)
域排序选项:
为了实现域排序的功能必须对文档进行索引(不能使用Index.NO),并且每个对应的文档必须包含一个语汇单元,也就不能对该域进行分词操作(例外情况是可以使用只会生成一个语汇单元的分析器,比如KeyWordAnalyzer)
多值域:
想象这样一种情况,一个文档用域来表示作者,但是一本书的作者可能不止一个,这时,我们可以在该域里写入多个不同的值,使其成为一个多值域
类似以下代码
Document document = new Document;
for(String author : authors){
document.add(
new Field ("author",author,Field.Store.YES,Field.Index.ANALYZED));
}
最新文章
- css文本换行相关属性及解释
- redis python-redis 安装详细步骤
- javascript变量名提升
- node中简单scoket介绍
- tabBaritem的图片偏移
- hdu5322 Hope
- linux tar.gz zip 解压缩 压缩命令
- [记录]calculate age based on date of birth
- poj 2823 Sliding Window(单调队列)
- c++之命名空间namespace
- hdu 4885 TIANKENG’s travel(bfs)
- Fedora 19的U盘安装 以及简单配置
- 读《31天学会CRM项目开发》记录4 - WEB服务配置
- VCenter6.0.0的安装过程
- Windows 10 无法使用搜索栏,显示一片空白
- 兼容Android 和 ios JavaScript copy paste
- mybatis 的sql语句及使用mybatis的动态sql mybatis防注入
- 卷积转换为矩阵运算中填充数的计算-GEMM
- JSON.stringify转化报错
- Winform窗体传值