hibernate一对一外键双向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接。
本系列将介绍Hibernate中主要的几种关联映射
Hibernate一对一主键单向关联
Hibernate一对一主键双向关联
Hibernate一对一外键单向关联
Hibernate一对一外键双向关联
Hibernate多对一单向关联
Hibernate多对一双向关联
Hibernate多对多关联
代码都写有注释,主要包括(核心配置文件,实体映射文件,实体类,测试类,数据库)主要操作有增删改查。
本篇主要介绍Hibernate一对一外键双向关联:
hibernate.cfg.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!-- 配置数据库连接驱动类 --> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <!-- 配置数据库连接字符串 --> <property name="connection.url"><![CDATA[jdbc:mysql://localhost:3306/test111?useUnicode=true&characterEncoding=utf8]]></property> <!-- 配置数据库连接用户名 --> <property name="connection.username">root</property> <!-- 配置数据库连接密码 --> <property name="connection.password">123456</property> <!-- 配置数据库方言 --> <property name="dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 配置数据库表生成策略 --> <!--<property name="hibernate.hbm2ddl.auto">update</property> --> <!-- 配置是否打印显示SQL语句 --> <property name="show_sql">true</property> <!-- 配置是否格式化显示SQL语句 --> <property name="format_sql">true</property> <!-- 配置hibernate是否自动提交事务 --> <!--<property name="hibernate.connection.autocommit">true</property> --> <!-- 配置实体类对应的映射文件 -->
<!-- 一对一双向外键关联 --> <mapping resource="com/great/entity5/People.hbm.xml"></mapping> <mapping resource="com/great/entity5/IdCard.hbm.xml"></mapping> </session-factory> </hibernate-configuration>
People.hbm.xml
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" > <hibernate-mapping package="com.great.entity5"> <!-- 配置实体类与数据库表的映射关系 --> <class name="People" table="people1"> <!-- 配置主键映射关系 --> <id name="id" column="id" type="int"> <!-- 配置主键生成策略 这个主键生成策略并没有什么影响 --> <generator class="native"> </generator> </id> <!-- 配置属性和表字段映射关系 一对外键一双向关联 --> <property name="pName" column="pName" type="string"></property> <many-to-one name="idCard" unique="true" cascade="all"> <column name="card_id"></column> </many-to-one> </class> </hibernate-mapping>
IdCard.hbm.xml
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.great.entity5"> <class name="IdCard" table="idcard1"> <id name="card_id" column="id" type="int"> <generator class="identity"> </generator> </id> <!-- 配置属性和表字段映射关系 一对一外键双向关联 --> <property name="cardCode" column="cardCode" type="string"></property> <one-to-one name="people" class="com.great.entity5.People" cascade="all" property-ref="idCard" /> </class> </hibernate-mapping>
People.java
package com.great.entity5; public class People { // 一对一外键双向关联 private int id; private String pName; private IdCard idCard; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getpName() { return pName; } public void setpName(String pName) { this.pName = pName; } public IdCard getIdCard() { return idCard; } public void setIdCard(IdCard idCard) { this.idCard = idCard; } }
IdCard.java
package com.great.entity5; public class IdCard { // 一对一外键双向关联 private int card_id; private String cardCode; private People people; public int getCard_id() { return card_id; } public void setCard_id(int card_id) { this.card_id = card_id; } public String getCardCode() { return CardCode; } public void setCardCode(String cardCode) { CardCode = cardCode; } public People getPeople() { return people; } public void setPeople(People people) { this.people = people; } }
TestOneToOneForeignBoth.java(测试类)
package com.great.test; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hibernate.cfg.Configuration; import org.junit.AfterClass; import org.junit.BeforeClass; import org.junit.Test; import com.great.entity5.IdCard; import com.great.entity5.People; public class TestOneToOneForeignBoth { static Session session; // 一对一外键双向关联 @BeforeClass public static void setUpBeforeClass() throws Exception { // 加载hibernate主配置文件 Configuration cfg = new Configuration().configure(); // 构建session工厂 SessionFactory sf = cfg.buildSessionFactory(); // 打开session session = sf.openSession(); } @AfterClass public static void tearDownAfterClass() throws Exception { // 关闭session,释放资源 session.close(); } // select1,通过people @Test public void testOneToOneSelect1() { People people = (People) session.get(People.class, 1); System.out.println("身份证号码:" + people.getIdCard().getCardCode()); System.out.println("姓名是:" + people.getpName()); } // select2,通过idCard @Test public void testOneToOneSelect2() { IdCard idCard = (IdCard) session.get(IdCard.class, 1); System.out.println("身份证号码:" + idCard.getCardCode()); System.out.println("姓名是:" + idCard.getPeople().getpName()); } // insert1数据,通过保存people来插入数据 @Test public void testOneToOneSave1() { Transaction ts = session.beginTransaction(); IdCard idCard = new IdCard(); idCard.setCardCode("124567891234566"); People people = new People(); people.setpName("张起灵2"); idCard.setPeople(people);// 可加可不加 people.setIdCard(idCard); session.save(people); ts.commit(); } // insert2数据,通过保存inCard来插入数据 @Test public void testOneToOneSave2() { Transaction ts = session.beginTransaction(); IdCard idCard = new IdCard(); idCard.setCardCode("124567891234566"); People people = new People(); people.setpName("张起灵2"); people.setIdCard(idCard);// 必须加,否则失败 idCard.setPeople(people); session.save(idCard); ts.commit(); } // delete1数据,删除people,级联删除inCard。发出两条查询两条删除语句 @Test public void testOneToOneDelete1() { Transaction ts = session.beginTransaction(); People people = (People) session.get(People.class, 12); session.delete(people); ts.commit(); } /* * delete2数据,通过删除idCard,级联删除people. * delete数据。发出两条查询两条删除语句,也是先删除people再删除idCard */ @Test public void testOneToOneDelete2() { Transaction ts = session.beginTransaction(); IdCard idCard = (IdCard) session.get(IdCard.class, 14); session.delete(idCard); ts.commit(); } // 更新数据1,通过people进行更新 @Test public void testOneToOneUpdate1() { Transaction ts = session.beginTransaction(); People people = (People) session.get(People.class, 11); people.setpName("张起灵1"); people.getIdCard().setCardCode("511381199612120254"); /* * session.update(people); * update和saveOrUpdate的区别在于后者在数据库中不存在此对象的情况下插入,所以效率低。 */ session.saveOrUpdate(people); ts.commit(); } // 更新数据2,通过idCard进行更新 @Test public void testOneToOneUpdate2() { Transaction ts = session.beginTransaction(); IdCard idCard = (IdCard) session.get(IdCard.class, 8); idCard.getPeople().setpName("张起灵3"); idCard.setCardCode("311381199612120254"); session.update(idCard); ts.commit(); } }
数据库:
people1表
三个字段id pName card_id(外键)
idcard1表
两个字段id cardCode
注意:在people表的card_id上建立外键关系。
hibernate一对一外键双向关联的更多相关文章
- Hibernate一对一外键双向关联(Annotation配置)
如上图所示:一个学生有一个学生证号,一个学生证号对应一名学生.在Hibernate中怎么用Annotation来实现呢? 学生类,主键是id:学生证的主键也是Id: Student.java pack ...
- hibernate一对一外键单向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- hibernate一对一主键双向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- hibernate一对一主键单向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- Hibernate一对一外键映射
Hibernate 一对一外键映射 ------------------------------ ----- ...
- Hibernate,一对一外键单向 记录。Timestamp 的一个坑。
首先是2张表 表A: 表B: 其中表B中的FormBaseId对应表A中的SubjectID. 数据库中没有设置外键关系. 下面是2个对应的实体 package questionnaire.model ...
- Hibernate,关系映射的多对一单向关联、多对一双向关联、一对一主键关联、一对一外键关联、多对多关系关联
2018-11-10 22:27:02开始写 下图内容ORM.Hibernate介绍.hibername.cfg.xml结构: 下图内容hibernate映射文件结构介绍 下图内容hibernate ...
- ORM框架Hibernate (四) 一对一单向、双向关联映射
简介 在上一篇博客说了一下多对一映射,这里再说一下一对一关联映射,这种例子在生活中很常见,比如一个人的信息和他的身份证是一对一.又如一夫一妻制等等. 记得在Java编程思想上第一句话是“一切皆对象”, ...
- hibernate之关于一对一单向,双向关联映射
[hibernate]之关于一对一单向,双向关联映射 首先我们来看,Hibernate官方对于一对一单向关联的解释: 基于外键关联的单向一对一关联和单向多对一关联差点儿是一样的. 唯一的不同就是单向一 ...
随机推荐
- Sql Server系列:分区表操作
1. 分区表简介 分区表在逻辑上是一个表,而物理上是多个表.从用户角度来看,分区表和普通表是一样的.使用分区表的主要目的是为改善大型表以及具有多个访问模式的表的可伸缩性和可管理性. 分区表是把数据按设 ...
- C#4.0泛型的协变,逆变深入剖析
C#4.0中有一个新特性:协变与逆变.可能很多人在开发过程中不常用到,但是深入的了解他们,肯定是有好处的. 协变和逆变体现在泛型的接口和委托上面,也就是对泛型参数的声明,可以声明为协变,或者逆变.什么 ...
- OpenCASCADE BRep Projection
OpenCASCADE BRep Projection eryar@163.com 一网友发邮件问我下图所示的效果如何在OpenCASCADE中实现,我的想法是先构造出螺旋线,再将螺旋线投影到面上. ...
- 在Linux系统下运行微信Web开发者工具
微信Web开发者工具只有window版本和mac版本,如果想要在Linux系统下运行微信Web开发者工具,需要花费很大周折. 注:带 * 的步骤或文件为不确定是否管用的步骤或文件.本人系统为Linux ...
- C++随笔:.NET CoreCLR之GC探索(4)
今天继续来 带大家讲解CoreCLR之GC,首先我们继续看这个GCSample,这篇文章是上一篇文章的继续,如果有不清楚的,还请翻到我写的上一篇随笔.下面我们继续: // Initialize fre ...
- js面向对象学习 - 对象概念及创建对象
原文地址:js面向对象学习笔记 一.对象概念 对象是什么?对象是“无序属性的集合,其属性可以包括基本值,对象或者函数”.也就是一组名值对的无序集合. 对象的特性(不可直接访问),也就是属性包含两种,数 ...
- WebApi基于Token和签名的验证
最近一段时间在学习WebApi,涉及到验证部分的一些知识觉得自己并不是太懂,所以来博客园看了几篇博文,发现一篇讲的特别好的,读了几遍茅塞顿开(都闪开,我要装逼了),刚开始读有些地方不理解,所以想了很久 ...
- Div Vertical Menu ver5
这个小功能,如果是算此次,已经是第5次修改了.可以从这里看到前4次:V1, http://www.cnblogs.com/insus/archive/2011/10/17/2215637.html V ...
- (翻译)FIFO In Hardware
翻译一些自己觉得有价值的材料,工作中碰到英语大多数是读,基本没有写或者翻的,翻得不好不到位的敬请指摘. 同时也附原文以供参考. http://electronics.stackexchange.com ...
- FineReport如何用JDBC连接阿里云ADS数据库
在使用FineReport连接阿里云的ADS(AnalyticDB)数据库,很多时候在测试连接时就失败了.此时,该如何连接ADS数据库呢? 我们只需要手动将连接ads数据库需要使用到的jar放置到%F ...