Spring Data JPA:Join 列上的 FindBy

mif*_*042 11 java spring-data-jpa

我在一对一映射中设置了两个实体,如下所示,并且我尝试在存储库中查询连接列,如下所示:

@Entity
@Table(name = "a")
@AllArgsConstructor
@NoArgsConstructor
@Data
@EqualsAndHashCode(callSuper=false)
public class A extends Auditable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column(unique = true)
    @Size(min = 1, max = 100)
    private String name;
}


@Entity
@Table(name = "b")
@AllArgsConstructor
@NoArgsConstructor
@Data
@EqualsAndHashCode(callSuper=false)
public class B extends Auditable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column
    @Size(min = 1, max = 100)
    private String name;

    @OneToOne
    @JoinColumn(name="aId", referencedColumnName = "aId")
    private A aId;

}
Run Code Online (Sandbox Code Playgroud)

在我的中BRepository.java,我正在尝试这样做:

@Component
public interface BRepository extends JpaRepository<B, Long> {
    List<B> findAllBByA_aId(String aId);
}
Run Code Online (Sandbox Code Playgroud)

我收到以下错误:

No property a found for type B! Did you mean 'aId'?

这不是在 spring-data 中查询连接列的正确方法吗?

Thi*_*kaD 9

由于您尚未id在 A 中定义列名称,因此列名称将默认为id。然后在类 B 中,您应该将 更改为referencedColumnNameid或者您可以简单地跳过该referencedColumnName属性,因为它可以直接从 OneToOne 关系中的目标实体派生)

@Entity
@Table(name = "b")
@AllArgsConstructor
@NoArgsConstructor
@Data
@EqualsAndHashCode(callSuper=false)
public class B extends Auditable {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column
    @Size(min = 1, max = 100)
    private String name;

    @OneToOne
    @JoinColumn(name="aId", referencedColumnName = "id")
    private A aId;

}
Run Code Online (Sandbox Code Playgroud)

在repository中,你需要用@Repositoryannotation来注释它,让Spring知道它应该被视为一个Repository Bean。

@Repository
public interface BRepository extends JpaRepository<B, Long> {
    
    @Query(value="select b from B b where B.aId.id=?1")
    List<B> findAllBByA_aId(String aId);
}
Run Code Online (Sandbox Code Playgroud)

或者你可以直接使用SPeL,

@Repository
public interface BRepository extends JpaRepository<B, Long> {
    
    List<B> findAllByaIdId(String aId);
}
Run Code Online (Sandbox Code Playgroud)