加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – WHERE子句中带有CASE WHEN的JPA查询.怎么做?

发布时间:2020-12-14 05:19:58 所属栏目:Java 来源:网络整理
导读:如何使用JPA运行如下所示的查询. (它适用于纯SQL) SELECT tFROM table tWHERE ( CASE WHEN (( ... subquery ... ) IS NULL) THEN (t.category IS NULL) ELSE (t.viewId = :viewId) END ) 我在IS遇到MismatchedTokenException 那么(t.category IS NULL) 可能
如何使用JPA运行如下所示的查询. (它适用于纯SQL)
SELECT t
FROM table t
WHERE
  (
    CASE WHEN (( ... subquery ... )  IS NULL)
    THEN (t.category IS NULL)
    ELSE (t.viewId = :viewId)
    END
  )

我在IS遇到MismatchedTokenException

那么(t.category IS NULL)

可能吗?或者我需要重写这个查询?

解决方法

您可以将where子句转换为:
where
    ((... my first condition ...) and (something is NULL))
    or
    (not (... first condition ...) and (something2 = otherthing))

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读