Many-To-Many (学生、课程、分数)

本文介绍了如何使用Java实现学生、课程及分数之间的多对多关系管理。通过建立Student、Course和Score三个实体类,利用注解定义了这些实体类间的关联关系。特别地,文章详细解释了如何使用JPA(Java Persistence API)的@ManyToMany、@JoinTable和@ManyToOne注解来维护多对多的关系。
[align=center][size=xx-large][color=red][b]Many-To-Many (学生、课程、分数)[/b][/color][/size][/align]
[color=red]多对多:[/color]
一个学生可以选多门课
一门课可以被多个学生选修

[color=red]多对一:[/color]
多组分数对应一个学生
多组分数对应一门课程

[color=red]多对多要有三张表[/color] 分别为:[color=red]student、course、sorce[/color]
[color=red]一、Student.java[/color]


import java.util.HashSet;
import java.util.Set;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;

@Entity
public class Student {
private int id;
private String name;
private Set<Course> courses = new HashSet<Course>();

@ManyToMany
//设置第三张表score与student和course表之间的外键连接,操作其中两张表的数据时,成绩表数据也会被操作
@JoinTable(name="score",
joinColumns=@JoinColumn(name="student_id", referencedColumnName="id"),
inverseJoinColumns=@JoinColumn(name="course_id", referencedColumnName="id")
)
public Set<Course> getCourses() {
return courses;
}
public void setCourses(Set<Course> courses) {
this.courses = courses;
}
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

}



[color=red]二、Course.java[/color]


import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;

@Entity
public class Course {
private int id;
private String name;
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

}


[color=red]
三、Score.java[/color]



import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;

@Entity
@Table(name="score")
public class Score {
private int id;
private int score;
private Student student;
private Course course;
@Id
@GeneratedValue
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getScore() {
return score;
}
public void setScore(int score) {
this.score = score;
}
@ManyToOne
@JoinColumn(name="student_id")
public Student getStudent() {
return student;
}
public void setStudent(Student student) {
this.student = student;
}

@ManyToOne
@JoinColumn(name="course_id")
public Course getCourse() {
return course;
}
public void setCourse(Course course) {
this.course = course;
}

}
1.引言 随着现代化教育的推进,学校管理系统逐步向数字化、自动化方向发展。学生成绩管理作为其中重要的一环,传统的手工管理方法已经无法满足高效、安全、规范的需求。为了提高管理效率,确保数据的准确性和安全性,设计一个学生成绩信息管理系统数据库,通过MySQL实现数据的高效存储和管理。 2.需求分析 2.1功能需求 该系统能够进行数据库的数据定义、数据操纵、数据控制等处理功能。具体功能应包括:可提供课程安排、课程成绩数据的添加、插入、删除、更新、查询,学生及教职工基本信息查询的功能。 2.2概念结构设计 根据学生成绩信息管理数据库设计需求抽象出学生、教师、课程、成绩四个实体,默认一门课程仅被一位老师讲授。对4个实体之间的关系进行分析如下: 一位学生会被多位老师教导,一位老师会教导多位学生,所有学生教师之间是多对多(m:n)的关系;一位学生可能会选修多门课程,一门课程会被多位学生选修,所以学生课程之间是多对多(m:n)的关系;一位学生会有多项成绩(具体指某学生一门课程分数),一项成绩仅被一位学生拥有,所以学生成绩是一对多(1:n)的关系;一位教师会讲授多门课程,一门课程会被一位教师讲授,所以教师课程的关系是一对多(1:n)的关系;一门课程拥有多项成绩,一项成绩仅被一门课程拥有,所以课程成绩的关系是一对多(1:n)的关系。 先分析一下然后给我可以生成ER图的文字脚本
11-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值