java里case when_java-如何在Hibernate Where子句中使用CASE WHEN

Plase给出了在HQL中使用CASE WHEN的示例.

我在代码中使用了以下查询.

int receiptNumber = 100;

String hql = "SELECT b FROM OOPExtract as b "

+"WHERE "

+" b.tranStatId =" +receiptNumber+ " AND "

+" b.orderType IN ('EMERGENCY', 'PLENARY', 'PETITION','EXTENSION','MOTION') AND "

+" CASE WHEN b.orderType == 'MOTION' " `enter code here`

+ "THEN "

+" b.status = 'MOTION_SIGNED' "

+" ELSE "

+" b.status LIKE '%%' "

+" END "

+" ORDER BY b.oopExtractId DESC";

但是运行时会生成以下异常

org.hibernate.hql.ast.QuerySyntaxException: unexpected token: = …..

解决方法:

这也适用于Hibernate 4 / JPA和Spring 4!

select

limite

from

Limite limite

join

fetch limite.limiteEnqs enq

join

fetch enq.limiteValors valor

where

limite.id = :limiteId

and :dataReferencia between valor.dtIniVig and valor.dtFimVig

and enq.vrAtributo1 = case limite.atributoId1

when 8 then :produtoId

else enq.vrAtributo1

end

标签:hibernate,hql,java,mysql

来源: https://codeday.me/bug/20191120/2042565.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值