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

Spring boot JPA 复合外键映射

如何解决Spring boot JPA 复合外键映射

我在为某些实体设置 jpa 映射时遇到问题。下面是我想要实现的场景。

有3张桌子:

  1. Users:存储用户信息。 (自动生成的 ID 是主键)
  2. Posts:存储公司发布的 Feed。 (自动生成的 ID 是主键)
  3. 喜欢:存储用户喜欢的提要。 ( User-Id,Post-Id 作为复合主键)

enter image description here

下面是我试图实现的代码,但它不起作用

@Entity(name = "likes")
@IdClass(LikesId.class)
public class Likes {

    @Id
    @ManyToOne(optional = false)
    @JoinColumn(name = "post_id")
    private Post post;

    @Id
    @ManyToOne(optional = false)
    @JoinColumn(name = "user_id")
    private User user;

    @UpdateTimestamp
    private Date timestamp;

    public Like (Post post,User user){
        this.setPost(post);
        this.setUser(user);
    }

}

下面是复合键的IdClass:

@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode
public class LikesId implements Serializable {

    @ManyToOne(optional = false)
    @JoinColumn(name = "post_id")
    private Post post;

    @ManyToOne(optional = false)
    @JoinColumn(name = "user_id")
    private User user;

}

我在 saveAndFlush 调用时遇到以下错误

java.lang.IllegalArgumentException: Can not set com.app.models.post.Post field com.app.models.likes.LikesId.post to java.lang.Long

解决方法

您的 id 类应如下所示。

@NoArgsConstructor
@AllArgsConstructor
@EqualsAndHashCode
public class LikesId implements Serializable {

    private Long postId;

    private Long userId;

}

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