【hibernate框架】多对多单向关联(Annotation实现)

本文介绍了多对多关系在数据库中的实现方式,通过师生关系的例子详细解释了如何使用中间表来建立这种联系,并展示了Hibernate中如何利用Annotation注解实现多对多关系。
什么情况下是多对多?
举个例子:一个老师可以教多个学生,每个学生也可以被多个老师教。这就是多对多的情况。
在数据库表中这种关系该怎么设计?很简单,加一张中间表。


设计模型:
table_student id<int> <pk>
table_teacher id<int> <pk>


中间表:
T_S t_id<int> <pk,fk2> s_id<int> <pk,fk1>


比如老师2教学生1,在中间表中就存2,1
老师2教学生3,在中间表中就存2,3
这就可以表示多对多的关系了。


hibernate中利用Annotation注解实现:
Student.java:
package cn.edu.hpu.many2many;


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


@Entity
@Table(name="m_student")
public class Student {
	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;
	}
	
}



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.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
	@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;
	}
	
	@ManyToMany
	public Set<Student> getStudents() {
		return students;
	}
	public void setStudents(Set<Student> students) {
		this.students = students;
	}
	
}


生成的建表语句:
 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 m_teacher_m_student (
        m_teacher_id integer not null,
        students_id integer not null,
        primary key (m_teacher_id, students_id)
    )


    alter table m_teacher_m_student 
        add index FK9536C8FA2DA52D4 (m_teacher_id), 
        add constraint FK9536C8FA2DA52D4 
        foreign key (m_teacher_id) 
        references m_teacher (id)


    alter table m_teacher_m_student 
        add index FK9536C8FA34A96CA5 (students_id), 
        add constraint FK9536C8FA34A96CA5 
        foreign key (students_id) 
        references m_student (id)


除了m_student和m_teacher表以外,还生成了一张m_teacher_m_student表,
里面的m_teacher_id属性和students_id分别添加了外键关联。


我如果想改变一下它默认生成表的名字,以及中间那张表默认列的名字,
这个时候怎么做?


做法:
一个Annotation属性叫做:@JoinTable(name="t_s")
加在@ManyToMany下面:
@ManyToMany
@JoinTable(name="t_s")
public Set<Student> getStudents() {
return students;
}


改中间表的字段名称:
@ManyToMany
@JoinTable(name="t_s",
joinColumns={@JoinColumn(name="teacher_id")},//指明的是当前这个实体类的表的名字(加s防止联合主键)
inverseJoinColumns={@JoinColumn(name="student_id")}//逆转的、对方的的表名(所对应的另一张表)
)
public Set<Student> getStudents() {
return students;
}


不需要背,会查文档即可。


转载请注明出处:http://blog.youkuaiyun.com/acmman

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

光仔December

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值