两个实体类的代码
@Entity
@Table(name="t_group")
public class Group {
@Id
@GeneratedValue
private int id;
private String name;
@OneToMany
private Set person = new HashSet();
//get.set方法省略
}
@Entity
@Table(name="t_person")
public class Person {
@Id
@GeneratedValue
private int id;
private String name;
//get.set方法省略
}
生成的表如下!
[图片说明](https://img-ask.csdn.net/upload/201708/22/1503410551_885573.jpg)
为什么在中间表里面,为person_id设置了一个unique key 为什么不为t_group_id设置?
unique key 唯一性约束,主要是防止在同一个group内插入两个相同的person。一对多关系,一个group可以对应多个person,但不能存在两个相同的person。如果为t_group_id设置了UNIQUE KEY,也就让这个字段不能唯一了,不能重复,那么就不存在一堆多关系了。例如,中间表中person_id和t_group_id是一条记录,这个group有多少个人,就会出现多少条记录,这些记录的person_id相同,但是t_group_id不同。如果唯一了,就只能一
个person对应一个group。
一对多(多对一)
多对多
你这在
@OneToMany
private Set person = new HashSet();
对人设置一对多
UNIQUE KEY的用途:主要是用来防止数据插入的时候重复的。
懂吧。
一对多人是一,防重复,group多对一,你说一那边可有重复的吗,那不就乱了,group这边的对应person那边的哪一个呢,是吧