【问题标题】:How to fetch a property only if it's not null in Hibernate仅当 Hibernate 中的属性不为空时如何获取属性
【发布时间】:2012-11-12 22:00:17
【问题描述】:

在 Hibernate 查询中,我如何检查属性是否为空?根据结果​​,我想获取该属性,如果它不为空,我必须获取另一个属性。

【问题讨论】:

    标签: hql jpql


    【解决方案1】:

    以下两种方式是有效的 HQL 查询,并且都是有效的 JPA 2.0 JPQL 查询。

    使用合并(返回第一个非 null,如果两者都为 null,则返回 null):

    SELECT coalesce(e.property, e.otherProperty) FROM SomeEntity e
    

    等效的select-case,有点长:

    SELECT CASE WHEN e.property IS NULL THEN e.otherProperty ELSE e.property END 
    FROM SomeEntity e
    

    【讨论】:

      猜你喜欢
      • 2020-09-28
      • 1970-01-01
      • 1970-01-01
      • 2020-05-13
      • 2023-02-26
      • 2012-03-10
      • 2016-08-29
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多