lucene日期索引与搜索

工具类里:
TimestampConverter类里的方法:
/**
* lucene建日期索引转换
* @param timestamp
* @return
*/
public String timestampToShortStr2(Timestamp timestamp){
Date date = new Date(timestamp.getTime());
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
return sdf.format(date);
}
/**
* 当前日期作为结束日期进行日期范围搜索时格式转换
* @param date
* @return
*/
public String timestampToShortStr2(Date date){
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
return sdf.format(date);
}


建索引类里:
TimestampConverter converter = new TimestampConverter();
String docDate = converter.timestampToShortStr2(documentInfo.getCreatedate());
doc.add(new Field("docDate", docDate , Field.Store.YES, Field.Index.TOKENIZED));

搜索类里:
//日期范围
String createDateStart = docSearchParam.getSearchCDateStart();
String createDateEnd = docSearchParam.getSearchCDateEnd();
if(!(NullHelper.nullOrBlank(createDateStart)&&NullHelper.nullOrBlank(createDateEnd))){
if(NullHelper.nullOrBlank(createDateStart)){
createDateStart = "20000101";
}else if(NullHelper.nullOrBlank(createDateEnd)){
//设置当前日期为结束日期
Date now = new Date();
TimestampConverter converter = new TimestampConverter();
createDateEnd = converter.timestampToShortStr2(now);
}
Term start = new Term("docDate",createDateStart.replace("-", ""));
Term end = new Term("docDate",createDateEnd.replace("-", ""));

Query rangeQuery = new RangeQuery(start, end, true);
booleanquery.add(rangeQuery, BooleanClause.Occur.MUST);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值