1.多对一单向关联
a.数据库表设计,在多方加外键(原则:不要产生数据冗余)
补充知识——数据库表设计三范式:
(1)要有主键,列不可分
(2)联合主键不能存在部分依赖
(3)不能存在传递依赖
b.annotation:
@Entity
@Table(name="t_group")
public class Group
{
@Id
@GeneratedValue
private int id;
private String name;
}
@Entity
@Table(name="t_user")
public class User
{
@Id
@GeneratedValue
private int id;
private String name;
@ManyToOne
private Group group;
}
c.xml:<many-to-one></many-to-one>
<class name="com.hibernate.Group" table="t_group">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
</class>
<class name="com.hibernate.User" table="t_user">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<many-to-one name="group" column="groupId"></many-to-one>
//此处的name是属性名
</class>
2.一对多单向关联
a.数据库表设计,在多方加外键
b.类:在一的一方存在多方的集合
c.annotation:
@Entity
@Table(name="t_group")
public class Group
{
@Id
@GeneratedValue
private int id;
private String name;
@OneToMany
@JoinColumn(name="groupId")//进行映射
private Set<User> users = new HashSet<User>();
//数据库表数据不应该有重复,用set最合适
//没有@JoinColumn(name="groupId")会生成中间临时表
}
d.xml:
<class name="com.hibernate.Group" table="t_group">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<set name="users">
<key column="groupId"></key>
<one-to-many class="com.hibernate.User"></one-to-many>
</set>
</class>
3.一对多(多对一)双向关联
a.annotation
@Entity
@Table(name="t_group")
public class Group
{
@Id
@GeneratedValue
private int id;
private String name;
@OneToMany(mappedBy="group")
private Set<User> users = new HashSet<User>();
//在数据库表中关联关系设在多方
//所以User作为主导
}
@Entity
@Table(name="t_user")
public class User
{
@Id
@GeneratedValue
private int id;
private String name;
@ManyToOne
private Group group;
}
b.xml:
<class name="com.hibernate.User" table="t_user">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<many-to-one name="group" column="groupId"></many-to-one>
//name="group"是外键名称,此处的name是属性名
//两处设置的column名称必须一致
</class>
<class name="com.hibernate.Group" table="t_group">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"></property>
<set name="users">
<key column="groupId"></key>
<one-to-many class="com.hibernate.User"></one-to-many>
</set>
</class>
11hibernate hibernate的关系映射之OneToMany和ManyToOne(重点)
最新推荐文章于 2019-02-25 17:47:37 发布