Lucene获取没有存储的排序字段的值

 

Lucene索引时字段可以设置为存储(Store.YES)或者不存储(Store.NO)。一般情况下,搜索完成之后会得到一个TopDocs对象,用它去获取ScoreDoc之后取出Document。使用Document获取存储在索引中的值。但有些排序字段是不存储的,在构造Document时使用的下面的方式:

doc.add(new Field("time", "2001", Store.NO, Index.NOT_ANALYZED_NO_NORMS));

这样在获取Document之后,并无法获取time字段的值。难道真无办法了?

仔细分析一下,Lucene是怎么排序的就知道time这个字段肯定会在索引中存至少一份的,不然一个文档的time怎么和另外一个文档的time去比较?

下面的代码解决了这个问题:

 

首先获取一个TopFieldDocs,之后用它获取ScoreDoc,而此时的ScoreDoc其实是FieldDoc的实例。强制把ScoreDoc转为FieldDoc之后获取FieldDocfields字段。这个字段是一个数组,里面存储了你在请求排序是传入的所有字段的值,并且按照传入的顺序进行保存。

上面代码中searchWithOneSortField、searchWithTwoSortField两个方法分别演示了在一个排序条件下和两个排序条件下的使用效果。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值