我在 hibernate 中的 LikeExpression 有过期问题(hibernate 3.5.5)

发布于 2024-10-29 06:08:40 字数 709 浏览 1 评论 0原文

看起来它不适用于ignorCase。 第一个断言返回 true。第二——假。有什么想法吗?

EntityManager entityManager = (EntityManager) applicationContext.getBean("entityManager");
HibernateTemplate hibernateTemplate = entityManager.getHibernateTemplate();
int size = hibernateTemplate.find("from Source where caption like '%Вход%'").size();
System.out.println("By Query: " + size);
assertTrue(size > 0);

DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Source.class);
detachedCriteria.add(Restrictions.like("caption", "Вход", MatchMode.ANYWHERE).ignoreCase());
List list = hibernateTemplate.findByCriteria(detachedCriteria);
System.out.println("By DC: " + list.size());
assertTrue(list.size() > 0);

Looks like it does not work with ignorCase.
The first assert returns true. Second - false. Any Ideas?

EntityManager entityManager = (EntityManager) applicationContext.getBean("entityManager");
HibernateTemplate hibernateTemplate = entityManager.getHibernateTemplate();
int size = hibernateTemplate.find("from Source where caption like '%Вход%'").size();
System.out.println("By Query: " + size);
assertTrue(size > 0);

DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Source.class);
detachedCriteria.add(Restrictions.like("caption", "Вход", MatchMode.ANYWHERE).ignoreCase());
List list = hibernateTemplate.findByCriteria(detachedCriteria);
System.out.println("By DC: " + list.size());
assertTrue(list.size() > 0);

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

神经大条 2024-11-05 06:08:40

尝试使用 ilike("caption", "Вход", MatchMode.ANYWHERE) 而不是 like(..).ignoreCase()

http://www.dil.univ-mrs.fr/ ~massat/docs/hibernate-3.1/api/org/hibernate/criterion/Restrictions.html

Try ilike("caption", "Вход", MatchMode.ANYWHERE) instead of like(..).ignoreCase()

http://www.dil.univ-mrs.fr/~massat/docs/hibernate-3.1/api/org/hibernate/criterion/Restrictions.html

滥情哥ㄟ 2024-11-05 06:08:40

尝试使用 Restrictions.ilike 而不是 Restrictions.like

Try Restrictions.ilike instead of Restrictions.like.

§普罗旺斯的薰衣草 2024-11-05 06:08:40

在大多数数据库(Postgres 除外)上,Hibernate 将不区分大小写的 like 执行为 lower(caption) like ?,其中 ?的结果>“%Вход%”.toLowerCase()。如您所见,在您的情况下,仅当数据库 lower() 的结果与 String.toLowerCase() 的结果不一致时,它才会产生 false >。例如,如果数据库区域设置配置不支持西里尔字符的大小写转换,则可能会发生这种情况。

On most databases (except Postgres) Hibernate executes case-insensitive like as lower(caption) like ?, where ? is a result of "%Вход%".toLowerCase(). As you can see, in your case it can produce false only if results of database lower() are inconsistent with results of String.toLowerCase(). It can happen, for example, if database locale configuration doesn't support case conversion for Cyrillic characters.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文