2

在下面的代码中.. 有两个别名作为Entity Object 参考。有时"caseStage" as stage可以null在数据库中。什么时候"caseStage"为空,我希望stage.name值为空String或自定义的值等"---"

session.createCriteria(CaseMasterPO.class)
       .createAlias("branch", "br")     // BranchPO.class
       .createAlias("caseStage", "stage") // CaseStagePO.class
       .setProjection(Projections.projectionList()
          .add(Projections.property("caseCode"))
          .add(Projections.property("br.zoneCode"))
          .add(Projections.property("stage.name")) // Problem, when stage == null
       )
       .add(Restrictions.eq("caseCode", caseCode)).uniqueResult();
4

2 回答 2

7

将 CriteriaSpecification.LEFT_JOIN 设置为别名函数

.createAlias("branch", "br" , CriteriaSpecification.LEFT_JOIN) .createAlias("caseStage", "stage", CriteriaSpecification.LEFT_JOIN)

于 2017-01-24T17:23:05.293 回答
2

@Koti Eswar的答案是正确的,但现在已弃用。

应该这样做:

        join('branch', JoinType.LEFT)
        createAlias('branch', 'br')

在 Grails 3.3.5 中测试

于 2020-02-14T16:12:15.220 回答