微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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接口加载您搜索的实体.

原文地址:https://www.jb51.cc/java/125494.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐