多对多映射我在实际项目中应用比较少,是一种双向的关联关系。
实现:在数据库中添加中间表来维护两个表的关联关联。
在映射文件中使用<set>标签管理,并在每一个持久化类中添加对方的集合
以员工和项目为背景来看一下具体实现:
一个员工可以参加多个项目,并且一个项目可以有多个员工,这个就是一个多对多映射。
1.如何建立员工和项目之间的关联关系,通过第三个表来实现。
首先来看一下数据库结构:
--员工表
CREATE TABLE EMPLOYEE
(
ID NUMBER(10) NOT NULL,
EMNAME VARCHAR2(255 CHAR),
EMSEX VARCHAR2(2 CHAR),
PRIMARY KEY(ID)
)
--项目表
CREATE TABLE PROJECT
(
ID NUMBER(10) NOT NULL,
PRNAME VARCHAR2(255 CHAR),
PRIMARY KEY(ID)
)
--员工项目关联关系表
CREATE TABLE PROEMP
(
EMP_ID NUMBER(10) NOT NULL,
PRO_ID NUMBER(10) NOT NULL,
PRIMARY KEY(EMP_ID,PRO_ID)
)
--该表的两个外键
ALTER TABLE SUNYQ.PROEMP ADD (CONSTRAINT FK_AAJJDHEGP8CRARVM34YRR639A FOREIGN KEY (PRO_ID) REFERENCES SUNYQ.PROJECT (ID),
CONSTRAINT FK_4RRTN484UGR027VMDDSPFGFIU FOREIGN KEY (EMP_ID) REFERENCES SUNYQ.EMPLOYEE (ID));
2.持久化类
Employee中持有Project的set集合
...
private int emid;
private String emname;
private String emsex;
private Set<Project> proSet = new HashSet<Project>();
public int getEmid() {
return emid;
}
public void setEmid(int emid) {
this.emid = emid;
}
...
Project中持有Employee的set集合
...
private int prid;
private String prname;
private Set<Employee> empSet = new HashSet<Employee>();
public Set<Employee> getEmpSet() {
return empSet;
}
public void setEmpSet(Set<Employee> empSet) {
this.empSet = empSet;
}
...
3.映射文件
映射文件需要仔细的说明一下:
①Employee.hbm.xml
在Employee持久化类中包含的是Project的set集合:proSet
<set>标签:name就是该对象porSet,table就是关联关系表名叫proemp
<key column="emp_id"/>表示:在proemp表中对应employee表的外键。
<many-to-many />标签:实际的映射关系,Employee与Project的映射关系。
<hibernate-mapping>
<class name="com.iteye.sunyq.hibernate.Employee" table="employee">
<id name="emid" type="integer">
<column name="id"></column>
<generator class="native"></generator>
</id>
<property name="emname" type="string">
<column name="emname"></column>
</property>
<property name="emsex" type="string" >
<column name="emsex" length="2"></column>
</property>
<!-- name:持久化类中set集合的名称 table:第三方表名 -->
<set name="proSet" table="proemp">
<!-- 在第三表里面查询emp_id值相应的employee记录 -->
<key column="emp_id"></key>
<!--对Project表中查找pro_id值相就的project记录 -->
<many-to-many class="com.iteye.sunyq.hibernate.Project" column="pro_id"></many-to-many>
</set>
</class>
</hibernate-mapping>
②Project.hbm.xml
在Project.java中包含的是Employee的set集合:empSet
<set标签:name为该集合对象empSet,table为关联关系表名proemp
<key column="pro_id"/>标签:在proemp表中对应Project表的外键字段名
<many-to-many标签:实际的映射关系,与pro_id对应的emp_id的信息
<hibernate-mapping>
<class name="com.iteye.sunyq.hibernate.Project" table="project">
<id name="prid" type="integer">
<column name="id"></column>
<generator class="native"></generator>
</id>
<property name="prname" type="string">
<column name="prname"></column>
</property>
<set name="empSet" table="proemp">
<key column="pro_id"></key>
<many-to-many class="com.iteye.sunyq.hibernate.Employee" column="emp_id"></many-to-many>
</set>
</class>
</hibernate-mapping>
4.测试类
Session session = HibernateUtil.getSession();
Transaction transaction = session.beginTransaction();
Project p1 = new Project("项目一");
Project p2 = new Project("项目二");
Employee e1 = new Employee("小王","男");
Employee e2 = new Employee("小张","女");
p1.getEmpSet().add(e1);//给项目1添加员工1
p1.getEmpSet().add(e2);//给项目1添加员工2
p2.getEmpSet().add(e1);//给项目2添加员工1
session.save(e1);
session.save(e2);
session.save(p1);
session.save(p2);
transaction.commit();
HibernateUtil.closeSession(session);
查看一下执行sql:
在看一下数据库情况:
employee
project
proemp
5.为了提高性能,可以设置inverse来指定维护方,和cascase级联关系方便维护。
- 大小: 48.8 KB
- 大小: 15.6 KB
- 大小: 16.1 KB
- 大小: 15 KB
分享到:
相关推荐
hibernate 映射关系学习入门 多对多实体映射 源码
NULL 博文链接:https://1028826685.iteye.com/blog/1536060
包含《多对多双向关联映射》《多对一单向关联映射》《多对一双向关联映射》《一对多单向关联映射》等文档,并有图解及例子,非常适合新手学习,尤其是刚刚接触hibernate,对映射关系不清楚的。。。。
Hibernate映射一对多关联关系
hibernate映射枚举类型,hibernate如何映射枚举类型
自动生成hibernate映射文件和实体类
Hibernate Map 多对多映射
关于hibernate映射和查询,使用MySQL,适合初学者的练习
根据实体类生成简单的Hibernate映射文件,对不用Myeclipse的童鞋还是有用
1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射: 1.1:一对多和多对一映射,举例说明: 学生和老师: 一个老师可以教多个学生 【一对多映射】 多个学生可以被一个老师教【多对一映射】 部门与员工: ...
Hibernate映射解析 七种映射关系
常用 Hibernate 映射配置说明.doc
hibernate双向多对多关联映射(注解版)
用来生成hibernate映射文件.从而实现不需手动写入。。。很实用的东东哦。。
hibernate单向多对多映射(XML版)
myeclipse自动生成hibernate映射文件
用Hibernate映射继承关系
Hibernate映射关系一对多 源代码
hibernate关联映射详解SSH 多对多,一对多关系对象映射