java – Hibernate Search,Lucene还是其他任何选择?
发布时间:2020-12-14 16:26:05 所属栏目:Java 来源:网络整理
导读:我有一个查询,在表11的字符串或文本字段的大小(500 000)上做ILIKE,但对于ILIKE显然太大,搜索查询需要20秒.数据库是postgres 8.4 我需要实现这个搜索要快得多. 我想到了什么: 我从所有需要搜索的列组合了另外的TVECTOR列,并在其上创建了全文索引.全文搜索速
我有一个查询,在表11的字符串或文本字段的大小(500 000)上做ILIKE,但对于ILIKE显然太大,搜索查询需要20秒.数据库是postgres 8.4
我需要实现这个搜索要快得多. 我想到了什么: >我从所有需要搜索的列组合了另外的TVECTOR列,并在其上创建了全文索引.全文搜索速度非常快.但是…我无法将此TVECTOR类型映射到我的.hbms中.所以这个想法掉下来了(无论如何我把它当作临时解决方案). 无论如何,现在这个表已经发生了,但是我希望解决方案更为通用,适用于与全文搜索有关的未来案例. 所有意见赞赏! 感谢名单 解决方法
我强烈建议Hibernate Search提供了一个非常简单的Hibernate和Lucene之间的桥梁. Rememeber你将在这里使用.您只需注释您希望能够搜索的域类的属性.然后,当您更新/插入/删除启用了搜索Hibernate Search的实体时,只需更新相关索引.这只有在发生数据库更改的事务被提交时才会发生,即如果回滚,则索引不会被破坏.
所以回答你的问题: 是的,您可以索引特定表上的特定列.您还可以验证字段的内容,以便您可以在字段的部分匹配.>根本不难使用,你只需要找出你想搜索的属性.告诉Hibernate在哪里保留其索引.然后可以使用EntityManager / Session接口加载您搜索的实体. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读