简化Hibernae Search的使用
Hibernate Search是基于Lucene的针对数据库数据数据进行全文索引的框架,其最大的优点是在对数据库数据进行操作同时自动维护Lucene索引文件,为开发人员节约大量的索引维护代码。开发人员需要基本掌握Lucene才能把Hibernate Search用起来,我们可以做一些工作让开发人员可以更加快速的将Hibernate Search应用起来,而不需要更多的去了解Lucene的知识。
?
一、首先实现一个FullTextCriteria的全文索引搜索条件构建器,具备以下的特性。
1. 默认根据业务实体上的全文索引配置,自动生成一个包含有标注了@Field注解的字段的MultiFieldQuery;如果有关联对象,同时需要包含关联对象上定义的@Field字段;这些可通过反射来自动获取。
2. 设置排序条件的接口,让开发人员可以方便的设置排序。
3. 设置必需条件的接口,让开发人员可以方便的设置简单的过滤条件。
4. 对查询字段调整的接口,让开发人员可以简单的在默认搜索的字段基础上方便的增加和移除查询字段。
5. 设置Lucene Query的接口,针对复杂条件可以自己构建Lucene查询条件,保留原生特性。
?
二、在泛型DAO中增加全文索引的搜索接口和分页搜索接口,传入FullTextCriteria作为搜索接口的参数,使开发人员只需要了解如何用FullTextCriteria构建全文搜索条件就可以快速的应用起全文搜索功能。