Hibernate Criteria API中Restrictions.like和.ilike的区别是什么?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (4)
  • 关注 (0)
  • 查看 (645)

Hibernate的CriteriaapiRestrictions.ilike具有以下功能:

一种不区分大小写的“like”,类似于Postgres-ilike。

这很酷。但是同一个类也有like职能,有更模糊的联系:

对命名的属性应用“like”约束

Criteria cr = session.createCriteria(Employee.class);

// To get records having fistName starting with zara
cr.add(Restrictions.like("firstName", "zara%"));

// Case sensitive form of the above restriction.
cr.add(Restrictions.ilike("firstName", "zara%"));
提问于
用户回答回答于
用户回答回答于

Hibernate的条件API具有Restrictions.ilike函数,它具有以下联系:

A case-insensitive "like", similar to Postgres ilike operator

这很酷。但同一类也有类似的功能,有更多模糊的联系:

Apply a "like" constraint to the named property

Criteria cr = session.createCriteria(Employee.class);

// To get records having fistName starting with zara
cr.add(Restrictions.like("firstName", "zara%"));

// Case sensitive form of the above restriction.
cr.add(Restrictions.ilike("firstName", "zara%"));
用户回答回答于

ilike将执行较低的输入值,而较低的列值。

select * from table where lower(column) like lower(?)

用户回答回答于

在PostgreSQL中,有‘iLike’和‘like’不同的操作符,所以在独立于列属性中区分大小写,这就是这种情况发生的原因。

所属标签

可能回答问题的人

  • 天使的炫翼

    17 粉丝531 提问7 回答
  • 最爱开车啦

    8 粉丝503 提问6 回答
  • 优惠活动秘书

    0 粉丝2 提问6 回答
  • Richel

    6 粉丝0 提问5 回答

扫码关注云+社区

领取腾讯云代金券