java – Hibernate Search,Lucene还是其他任何选择?

我有一个查询,在表11的字符串或文本字段的大小(500 000)上做ILIKE,但对于ILIKE显然太大,搜索查询需要20秒.数据库是postgres 8.4

我需要实现这个搜索要快得多.

我想到了什么:

>我从所有需要搜索的列组合了另外的TVECTOR列,并在其上创建了全文索引.全文搜索速度非常快.但是…我无法将此TVECTOR类型映射到我的.hbms中.所以这个想法掉下来了(无论如何我把它当作临时解决方案).
>休眠搜索(今天第一次听到)似乎有希望,但是我需要有经验的意见,因为我不想进入新的API,可能不是最简单的API,可以做得更简单一些.
Lucene

无论如何,现在这个表已经发生了,但是我希望解决方案更为通用,适用于与全文搜索有关的未来案例.

所有意见赞赏!

感谢名单

解决方法

我强烈建议Hibernate Search提供了一个非常简单的Hibernate和Lucene之间的桥梁. Rememeber你将在这里使用.您只需注释您希望能够搜索的域类的属性.然后,当您更新/插入/删除启用了搜索Hibernate Search的实体时,只需更新相关索引.这只有在发生数据库更改的事务被提交时才会发生,即如果回滚,则索引不会被破坏.

所以回答你的问题:

是的,您可以索引特定表上的特定列.您还可以验证字段的内容,以便您可以在字段的部分匹配.>根本不难使用,你只需要找出你想搜索属性.告诉Hibernate在哪里保留其索引.然后可以使用EntityManager / Session接口加载您搜索的实体.

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...