java query dsl_java – QueryDsl – 具有字符串值的case表达式

QueryDsl 3.3.4

Hibernate 3.6.10-最终版

我有两个实体:

public class Document {

private Confirmation confirmation;

}

public class Confirmation {

...

}

我需要这样的查询:

SELECT count(d.id), CASE WHEN d.confirmation_id IS NULL then 'NOT_CONFIRMED' else 'CONFIRMED' END as confirmed FROM document d GROUP BY confirmed;

所以它应该按照上面的case表达式的结果进行分组.

现在,将案例部分翻译为querydsl:

StringExpression confirmExp = new CaseBuilder()

.when(Expressions.booleanTemplate("confirmation_id is null"))

.then(Expressions.stringTemplate("NOT_CONFIRMED"))

.otherwise(Expressions.stringTemplate("CONFIRMED"));

我正在使用.when(Expressions.booleanTemplate(“confirmation_id为null”))以避免加入确认表.

使用这样的表达式运行查询我在下面得到一个例外.

这是另一个hibernate错误或这种情况需要不同吗?

java.lang.IllegalStateException: No data type for node: >org.hibernate.hql.ast.tree.CaseNode

+-[CASE] CaseNode: ‘case’

| +-[WHEN] SqlNode: ‘when’

| | +-[IS_NULL] IsNullLogicOperatorNode: ‘is null’

| | | -[IDENT] IdentNode: ‘confirmation_id’ {originalText=confirmation_id}

| | -[IDENT] IdentNode: ‘NOT_CONFIRMED’ {originalText=NOT_CONFIRMED}

| -[ELSE] SqlNode: ‘else’

| -[IDENT] IdentNode: ‘CONFIRMED’ {originalText=CONFIRMED}

org.hibernate.hql.ast.tree.SelectClause.initializeExplicitSelectClause(SelectClause.java:156)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值