【hibernate框架】多对多双向关联(Annotation实现)
来源:互联网 发布:哪个软件上有原味 编辑:程序博客网 时间:2024/06/05 02:38
多对多的双向关联:(非常少用)
通过老师可以知道他教了多少学生,这是单项多对多。而如果同时通过学生知道有多少个老师教他,那么就是多对多双向的关联。
Annotation实现:
Student.java:
Teacher.java:
在hibernate.cfg.xml中配置:
生成的sql语句:
create table m_student (
id integer not null auto_increment,
name varchar(255),
primary key (id)
)
create table m_teacher (
id integer not null auto_increment,
name varchar(255),
primary key (id)
)
create table t_s (
teacher_id integer not null,
student_id integer not null,
primary key (teacher_id, student_id)
)
alter table t_s
add index FK1BF687B5893C2 (teacher_id),
add constraint FK1BF687B5893C2
foreign key (teacher_id)
references m_teacher (id)
alter table t_s
add index FK1BF686ABD4922 (student_id),
add constraint FK1BF686ABD4922
foreign key (student_id)
references m_student (id)
通过老师可以知道他教了多少学生,这是单项多对多。而如果同时通过学生知道有多少个老师教他,那么就是多对多双向的关联。
Annotation实现:
Student.java:
package cn.edu.hpu.many2many;import java.util.HashSet; import java.util.Set;import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.Id;import javax.persistence.ManyToMany;import javax.persistence.Table;@Entity@Table(name="m_student")public class Student {private int id;private String name;private Set<Teacher> teachers=new HashSet<Teacher>();@ManyToMany(mappedBy="students")public Set<Teacher> getTeachers() {return teachers;}public void setTeachers(Set<Teacher> teachers) {this.teachers = teachers;}@Id@GeneratedValuepublic 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;}}
Teacher.java:
package cn.edu.hpu.many2many;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;import javax.persistence.Table;import cn.edu.hpu.many2many.Student;@Entity@Table(name="m_teacher")public class Teacher {private int id;private String name;private Set<Student> students=new HashSet<Student>();//选择set的原因是因为,set互相之间不会有重复的//跟数据库模型比较匹配@Id@GeneratedValuepublic 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;}@ManyToMany@JoinTable(name="t_s",joinColumns={@JoinColumn(name="teacher_id")},//指明的是当前这个实体类的表的名字(加s防止联合主键)inverseJoinColumns={@JoinColumn(name="student_id")}//逆转的、对方的的表名(所对应的另一张表))public Set<Student> getStudents() {return students;}public void setStudents(Set<Student> students) {this.students = students;}}
在hibernate.cfg.xml中配置:
<mapping class="cn.edu.hpu.many2many.Student"/><mapping class="cn.edu.hpu.many2many.Teacher"/>
生成的sql语句:
create table m_student (
id integer not null auto_increment,
name varchar(255),
primary key (id)
)
create table m_teacher (
id integer not null auto_increment,
name varchar(255),
primary key (id)
)
create table t_s (
teacher_id integer not null,
student_id integer not null,
primary key (teacher_id, student_id)
)
alter table t_s
add index FK1BF687B5893C2 (teacher_id),
add constraint FK1BF687B5893C2
foreign key (teacher_id)
references m_teacher (id)
alter table t_s
add index FK1BF686ABD4922 (student_id),
add constraint FK1BF686ABD4922
foreign key (student_id)
references m_student (id)
转载请注明出处:http://blog.csdn.net/acmman
0 0
- 【hibernate框架】多对多双向关联(Annotation实现)
- 【hibernate框架】一对多(多对一)双向关联(Annotation实现)
- 【hibernate框架】多对多单向关联(Annotation实现)
- 【hibernate框架】多对一单向关联(Annotation实现)
- 【hibernate框架】多对多双向关联(XML实现)
- Hibernate多对多双向关联(Annotation配置)
- Hibernate多对多双向关联(Annotation配置)
- Hibernate多对多双向关联(Annotation配置)
- Hibernate annotation 多对多双向关联(很少用)
- 【hibernate框架】一对多(多对一)双向关联(XML实现)
- Hibernate Annotation 多对多 双向 示例
- Hibernate Annotation 多对一 双向
- hibernate多对多关联双向一对多实现
- Hibernate关系映射(七)多对多双向关联@ManyToMany Annotation方式
- Hibernate annotation 多对多单向关联
- Hibernate Annotation 多对一单向关联
- Hibernate多对多双向关联映射
- Hibernate 多对多双向关联
- Android 录制视频添加时间水印
- Cake - ZOJ 3537 凸包+dp三角划分
- Hibernate持久化的理解
- 并查集详解
- IOS开发- UIScrollView
- 【hibernate框架】多对多双向关联(Annotation实现)
- C++“异常处理”
- java 线程同步实例
- 黑马程序员 -- IOS C语言 流程控制1
- you are not authorized to use this service
- Java泛型简明教程
- yum 安装mysql5.5
- Java XML使用Dom4J从指定节点下寻找指定不重复名称的单节点
- C/C++中算法运行时间的三种计算方式(By 虚怀若谷)