Hibernate的many-to-many双向关联的配置办法
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2016-1-25 16:18:31 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping package="cn.opfo.app.domain">
<class name="Person" table="t_person">
<id name="id" type="java.lang.Integer">
<column name="ID" />
<generator class="native" />
</id>
<property generated="never" lazy="false" name="name"
type="java.lang.String">
<column name="NAME" />
</property>
<property generated="never" lazy="false" name="passowrd"
type="int">
<column name="PASSOWRD" />
</property>
<property generated="never" lazy="false" name="birthDay"
type="java.util.Date">
<column name="BIRTHDAY" />
</property>
<!--
table不配置时,可正常创建但多出一个无用表,但在通过主表查询从表时会
因找主表对应创建的表而无法找到对应从表而出现异常。
所以建议二个表都要配置中间关联表,且名称一致。
inverse配置方法:因为有级联,所以无需二个对象都来提交
此处在配置文件中需要在Person表的Set配置片段设定inverse="false",即由Person表管理级联关系
而在Address对象的Set配置片段设定inverse="true",即同意级联关系交给Person对象进行管理
通常二者设定相反,由设定inverse="false"的一方控制级联关系
反之亦然
如果设定相同,则在CUID中双方都要对数据进行处理,即失去级联的意义了。
-->
<set name="addressSet" cascade="all" inverse="false" table="person_join_address">
<!-- key指定关联关系列,是本对象ID对应在中间表中的索引列 -->
<key column="p_id" />
<!-- 指定另一对象(Set集合)中ID在中间表中所对应的索引列(对象名+属性名)-->
<many-to-manyclass="Address" column="a_id"/>
</set>
</class>
<class name="Address" table="t_address">
<id name="id">
<column name="ID" />
<generator class="native"/>
</id>
<property generated="never" lazy="false" name="descs"
type="java.lang.String">
<column name="DESCS" />
</property>
<property generated="never" lazy="false" name="code" type="int">
<column name="CODE" />
</property>
<!--
table不配置时,可正常创建但多出一个无用表,但在通过主表查询从表时会
因找主表对应创建的表而无法找到对应从表而出现异常。
所以建议二个表都要配置中间关联表,且名称一致。
inverse配置方法:因为有级联,所以无需二个对象都来提交
此处在配置文件中需要在Person表的Set配置片段设定inverse="false",即由Person表管理级联关系
而在Address对象的Set配置片段设定inverse="true",即同意级联关系交给Person对象进行管理
通常二者设定相反,由设定inverse="false"的一方控制级联关系
反之亦然
如果设定相同,则在CUID中双方都要对数据进行处理,即失去级联的意义了。
-->
<set name="personSet" cascade="all" inverse="true" table="person_join_address">
<!-- key指定关联关系列,是本对象ID对应在中间表中的索引列 -->
<key column="a_id"/>
<!-- 指定另一对象(Set集合)中ID在中间表中所对应的索引列(对象名+属性名)-->
<many-to-many class="Person"column="p_id"/>
</set>
</class>
</hibernate-mapping>
* Junit测试代码
*/
private SessionFactory sFactory;
Session session;
Transaction tx;
/*
* 测试前进行初始化
*/
public void setUp() throws Exception {
System.out.println("-----初始化数据------");
Configuration config = new Configuration().configure();
// ServiceRegistry sr = new
// StandardServiceRegistryBuilder().applySettings(config.getProperties()).build();
// sFactory = config.buildSessionFactory(sr);
sFactory = config.buildSessionFactory();
session = sFactory.openSession();
}
* 测试之后释放数据
*/
@After
public void tearDown() throws Exception {
System.out.println("-----释放化数据------");
if (session.isOpen()) {
session.close();
}
}
@Test
public void testOne2OneII(){
//定义人的集合
Set<Person> pSet = new HashSet<>();
Person p1 = new Person("wanglifu",134324,new Date());
Person p2 = new Person("wanglili",434321,new Date());
pSet.add(p1);
pSet.add(p2);
//定义地址的集合
Set<Address> aSet = new HashSet<Address>();
Address a1 = new Address("江苏盐城", 224562);
Address a2 = new Address("江苏南京", 224556);
aSet.add(a1);
aSet.add(a2);
//每个人和多个地址关联
p1.setAddressSet(aSet);
p2.setAddressSet(aSet);
//每个地址与多人建立关联
// a1.setPersonSet(pSet);
// a2.setPersonSet(pSet);
tx = session.beginTransaction();
//因为有级联,所以无需二个对象都来提交
//此处在配置文件中需要在Person表的Set配置片段设定inverse="false",即由Person表管理级联关系
//而在Address对象的Set配置片段设定inverse="true",即同意级联关系交给Person对象进行管理
//二者设定相反,由设定inverse="false"的一方控制级联关系
//反之亦然
session.persist(p1);
session.persist(p2);
// session.persist(a1);
// session.persist(a2);
tx.commit();
}
Hibernate的many-to-many双向关联的配置办法的更多相关文章
- Hibernate多对多双向关联的配置
Hibernate的双向多对多关联有两种配置方法:那我们就来看看两种方案是如何配置的. 一.创建以各自类为类型的集合来关联 1.首先我们要在两个实体类(雇员<Emploee>.工程< ...
- Hibernate(六)一对一双向关联映射
在上次的博文Hibernate从入门到精通(五)一对一单向关联映射中我们讲解了一下一对一单向关联映射, 这次我们继续讲解一下与之对应的一对一双向关联映射. 一对一双向关联 与一对一单向关联映 射所不同 ...
- ORM框架Hibernate (四) 一对一单向、双向关联映射
简介 在上一篇博客说了一下多对一映射,这里再说一下一对一关联映射,这种例子在生活中很常见,比如一个人的信息和他的身份证是一对一.又如一夫一妻制等等. 记得在Java编程思想上第一句话是“一切皆对象”, ...
- 【Hibernate步步】--一对一映射双向关联具体解释(两)
很抱歉.有两天没更新博客文章,不要写文章一天真的感觉很是空的啊.制定一个写作习惯,想改也改不掉啊.说点题外话,前两天我收到一封私人信件给朋友,我写邀请函的文章OWS文章.一种技术用于研究图标工具,这位 ...
- Hibernate多对多映射(双向关联)实例详解——真
一个学生可以选多门课 一门课程有多个学生上 实现步骤: 一.学生 (1)数据库创建学生数据表students,包含id,name字段 设置id字段为主键,类型:bigint,自增 设置name字段,类 ...
- Hibernate一对一外键双向关联(Annotation配置)
如上图所示:一个学生有一个学生证号,一个学生证号对应一名学生.在Hibernate中怎么用Annotation来实现呢? 学生类,主键是id:学生证的主键也是Id: Student.java pack ...
- grails一对多双向关联
前面分享了一些学习grails的心得,可是grails的知识还远不止这些,这次整理了一点有关grails一对多双向关联关系的知识.我认为这样的关联用的地方太多了,这次准备的样例是城市和区域的相关样例. ...
- hibernate多对一双向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- hibernate一对一外键双向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
随机推荐
- Linux phpbb论坛的安装(中文版)
1:建立文件夹
- [poj3017] Cut the Sequence (DP + 单调队列优化 + 平衡树优化)
DP + 单调队列优化 + 平衡树 好题 Description Given an integer sequence { an } of length N, you are to cut the se ...
- [问题2014A01] 解答一(第一列拆分法,由张钧瑞同学提供)
[问题2014A01] 解答一(第一列拆分法,由张钧瑞同学提供) (1) 当 \(a=0\) 时,这是高代书复习题一第 33 题,可用升阶法和 Vander Monde 行列式来求解,其结果为 \[ ...
- [像黑客一样生活] shell终端听音乐之网易云shell版
这是一个Python程序,使用Python构建,并以mpg123作为后端.Follow me... 特点: Vim 式的流畅操作,支持快捷键绑定 支持电台.收藏等各种特色功能 支持 OS X 及各类 ...
- Intellij自动下载导入框架包
忽然发现intellij尽然可以自动导入 框架所需的包,而且可以选择jar包版本,瞬间发现Maven,gradle管理jar包还得写配置文件弱爆了. 以Hibernate为例: 1.ProjectSt ...
- 32位和64位系统区别及int字节数
理论上来讲 我觉得数据类型的字节数应该是由CPU决定的,但是实际上主要由编译器决定(占多少位由编译器在编译期间说了算). 常用数据类型对应字节数 可用如sizeof(char),sizeof(ch ...
- table插件实现
选择.取消.全选.全部取消.获取行ids /** * Created by lizongqiong on 2016/1/8. */ var $ = require('jquery'); var tab ...
- linux下查看某软件是否已安装, ubuntu安装deb包
1.rpm包安装的,可以用rpm -qa看到,如果要查找某软件包是否安装,用 rpm -qa | grep “软件或者包的名字”. [root@hexuweb102 ~] rpm -qa | grep ...
- Android复习指南
基础无外乎几部分:语言(C/C++或java),操作系统,TCP/IP,数据结构与算法,再加上你所熟悉的领域.这里面其实有很多东西,各大面试宝典都有列举. 在这只列举了Android客户端所需要的和我 ...
- Git实现从本地添加项目到远程仓库
Git是现在最流行的版本控制系统之一了,今天也试试了,成功了上传了远程仓库,接下来看看我是怎么做的. (ps:七牛抓取不到图片,请移步:http://blog.csdn.net/u011043843/ ...