首页 > 解决方案 > 从视图中选择并插入表 Spring JPA

问题描述

我有两个实体,称为学生和课程。它们以下列格式存储在表中

学生

ID
1 约翰尼 古德
2 母鹿
3 泰德 琼斯

课程

ID 姓名 主题
1 结石 数学
2 生物学 科学
3 化学 科学

Student 和 Course 具有存储在名为 Student_Course 的表中的多对多关系

Student_Course

学生卡 course_id
1 1
2 3

我有一个名为 v_student_course 的 Student_Course 视图,它包含 student_id、course_id 和主题(从课程表中检索)。

v_student_course

学生卡 course_id 主题
1 1 数学
2 3 科学

在我的 Springboot 应用程序中,我有一个 Student 类和一个 Course 类,它们分别看起来像这样

@NoArgsConstructor
@AllArgsConstructor
@Table(name = "Student")
public class Student {
    @GeneratedValue(generator = "generator")
    @Column(name = "id")
    protected @Id int id;

    @Column(name = "first_name")
    protected String firstName;

    @Column(name = "last_name")
    protected String lastName;

    //getters and setters left out for this example
}
@NoArgsConstructor
@AllArgsConstructor
@Table(name = "Course")
public class Course{
    @GeneratedValue(generator = "generator")
    @Column(name = "id")
    protected @Id int id;

    @Column(name = "name")
    protected String name;

    @Column(name = "subject")
    protected String subject;

    //getters and setters left out for this example
}

我必须通过显示学生分配的课程来表示学生和课程之间的多对多关系。但是,所有选择都必须使用视图 v_student_course 完成,并且所有插入/更新必须使用表 Student_Course 完成。

  1. 我应该使用 ManyToMany 注释来做到这一点吗?但是,我注意到如果学生没有与课程相关联,这将导致 NullPointerExceptions。或者我应该为桥关系创建一个名为 StudentCourse.java 的单独类?

  2. 我如何声明选择必须来自与插入/更新不同的表/视图?

标签: javaspringspring-bootjpaspring-data-jpa

解决方案


我通过将此代码添加到 Student 类来解决这个问题

@ManyToMany(fetch = FetchType.LAZY, targetEntity = Course.class)
@JoinTable(name = "v_student_course",
    joinColumns = { @JoinColumn(name = "student_id", referencedColumnName = "id") },
    inverseJoinColumns = { @JoinColumn(name = "course_id", referencedColumnName = "id")})
protected List<Course> courses = new ArrayList<>();

我将此代码添加到课程类

@ManyToMany(mappedBy = "courses")
protected List<Student> students = new ArrayList<>();

然后我将它添加到我的 StudentRepository 界面

@Modifying
@Query (
    value = "INSERT INTO student_course (student_id, course_id) "
            "VALUES (:studentId, :courseId)",
    nativeQuery = true
)
public void saveStudentCourse(@Param("studentId") String studentId,
                              @Param("courseId") String courseId);

现在每当我搜索学生时,它也会从 v_student_course 中选择与学生相关的课程,但是当我插入新的学生课程关联时,它会直接插入到表中。


推荐阅读