繁体   English   中英

左外连接与 Hibernate 5 核

[英]LEFT OUTER JOIN with Hibernate 5 Core

我有两个实体(EntityA 和 EntityB),它们之间有一个可选的 @OneToOne 关系。

实体A:

@Setter
@Getter
@NoArgsConstructor
@Entity(name = "EntityA")
public class EntityA {

  @Id
  private Long id;

  @OneToOne(targetEntity = EntityB.class, mappedBy = "entityA", fetch = FetchType.LAZY, cascade = CascadeType.ALL, optional = true)
  private EntityB entityB;

  // other members
}

实体B:

@Setter
@Getter
@NoArgsConstructor
@Entity(name = "EntityB")
public class EntityB {

  @Id
  private Long id;

  @OneToOne(targetEntity = EntityA.class, fetch = FetchType.LAZY)
  @MapsId
  @JoinColumn(name = "id")
  private EntityA entityA;

  @Column(name = "status", nullable = false, unique = false)
  private Short status;

  // other members
}

我想 select 所有在实体 B 上没有任何对应关系的实体 A,或者如果有,则 entityB 状态应为 0。

从普通的 SQL 开始,我的目标是:

SELECT a.*
  FROM EntityA a
  LEFT JOIN EntityB b ON a.id = b.id
  WHERE b.id IS NULL OR b.status = 0

使用 Hibernate 5 核和 PostgreSQL 实现这一目标的最佳策略是什么?

我的方法是:

getSession().createQuery("SELECT a FROM EntityA a LEFT JOIN a.entityB b " +
                            "WHERE b IS NULL OR b.status = :status", EntityA.class)
                    .setParameter("status", (short) 0);

这是正确的方法吗?

我如何渴望在同一个查询中获取 EntityB 实体?

谢谢。

您的查询看起来正确。 此外,如果您想急切地获取 EntityB,只需添加“FETCH”即可查询

createQuery(
    "SELECT a FROM EntityA a " +
    "LEFT JOIN FETCH a.entityB b " +
    "WHERE b IS NULL " +
    "OR b.status = :status", EntityA.class).setParameter("status", (short) 0)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM