sqlRestriction的使用

在Criteria查询中  

使用 sqlRestriction()方法来提供SQL语法作限定查询,作为where字句
查看官方给的例子,如下
List cats = sess.createCriteria(Cat.class) 
.add( Restrictions.sqlRestriction("lower({alias}.name) like lower(?)", "Fritz%", Hibernate.STRING) ).list();

直接拿着官方的代码试了下,报错,点进去看了看源代码,如下

/**
* Create a restriction expressed in SQL with one JDBC parameter. Any occurrences of <tt>{alias}</tt> will be
* replaced by the table alias.
*
* @param sql The SQL restriction
* @param value The parameter value
* @param type The parameter type
*
* @return The Criterion
*
* @see SQLCriterion
*/
public static Criterion sqlRestriction(String sql, Object value, Type type) {
return new SQLCriterion( sql, value, type );
}

第一个是参数String类型,是SQL语句的条件部分,第二个参数是参数值,第三个参数是类型

根据案例和源代码,可以推断出{alias}.name中{alias}是表的别名,我用的是user表,于是根据理解,这样写了下,如下

Criteria criteria = session.createCriteria(User.class);
criteria.add(Restrictions.sqlRestriction(“lower({User}.name ) LIKE lower(?)", "cater%", Hibernate.STRING));

结果还是报错,把Hibernate设置成自动打印出sql语句后,sql如下

Hibernate: 
    select
        this_.id as id0_0_,
        this_.age as age0_0_,
        this_.birth as birth0_0_,
        this_.name as name0_0_ 
    from
        user this_ 
    where
        lower(this_).name like lower(?) 

可以看到lower也被打印了出来,而且Hibernate会自动给别起别名,所以下面的形式,别名也对应不上

{User}.name  LIKE ?

于是抱着试一试的态度,改成了这样:

Criteria criteria = session.createCriteria(User.class);
criteria.add(Restrictions.sqlRestriction(“{alias}.name LIKE lower(?)", "cater%", Hibernate.STRING));

 这次对了,打印的sql为

Hibernate: 
    select
        this_.id as id0_0_,
        this_.age as age0_0_,
        this_.birth as birth0_0_,
        this_.name as name0_0_ 
    from
        user this_ 
    where
        this_.name like ? 

 看来那里还必须写成{alias},那alias究竟是什么意思呢?是别名的意思,我的理解是,hibernate把{alias}当成了通配符

sqlRestriction的理解

标签:

原文地址:http://www.cnblogs.com/liuconglin/p/5686766.html

转载于:https://www.cnblogs.com/lp2cx/p/9576633.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值