微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Spring Data JPA:连接列上的 FindBy

如何解决Spring Data JPA:连接列上的 FindBy

我已经在一对一映射中设置了两个如下所示的实体,并且我正在尝试在我的存储库中查询如下所示的 joincolumn:

@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;

}

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

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

我收到以下错误

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

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

解决方法

由于您尚未为 A 中的 id 定义列名称,因此列名称将默认为 id。然后在 B 类中,您应该将 referencedColumnName 更改为 id(否则您可以简单地跳过 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;

}

在存储库中,您需要使用 @Repository 注释对其进行注释,以让 Spring 知道它应该被视为存储库 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);
}

或者你可以直接使用 SPeL,

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。