hibernate一对一主键唯一外键关联(二)
1.新建工程项目hibernate_one2one_ufk_2,添加hibernate所需的Jar包和数据库驱动的Jar包。
2.编写工具类HibernatUtils.java和ExportDB.java,它的代码如下:
HibernateUtils.java
- package com.i51pro.hibernate;
- import org.hibernate.Session;
- import org.hibernate.SessionFactory;
- import org.hibernate.cfg.Configuration;
- public class HibernateUtils {
- private static SessionFactory sessionFactory;
- static {
- try {
- Configuration cfg = new Configuration().configure();
- sessionFactory = cfg.buildSessionFactory();
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- public static SessionFactory getSessionFactory() {
- return sessionFactory;
- }
- public static Session getSession() {
- return sessionFactory.openSession();
- }
- public static void closeSession(Session session) {
- if (session != null) {
- if (session.isOpen()) {
- session.close();
- }
- }
- }
- }
ExportDB.java
- package com.i51pro.hibernate;
- import org.hibernate.cfg.Configuration;
- import org.hibernate.tool.hbm2ddl.SchemaExport;
- public class ExportDB {
- /**
- * @param args
- */
- public static void main(String[] args) {
- Configuration cfg = new Configuration().configure();
- SchemaExport export = new SchemaExport(cfg);
- export.create(true, true);
- }
- }
3.编写实体类和映射文件,代码如下:
IdCard.java
- package com.i51pro.hibernate;
- public class IdCard {
- private int id;
- private String cardNo;
- private Person person;
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getCardNo() {
- return cardNo;
- }
- public void setCardNo(String cardNo) {
- this.cardNo = cardNo;
- }
- public Person getPerson() {
- return person;
- }
- public void setPerson(Person person) {
- this.person = person;
- }
- }
Person.java
- package com.i51pro.hibernate;
- public class Person {
- private int id;
- private String name;
- private IdCard idCard;
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public IdCard getIdCard() {
- return idCard;
- }
- public void setIdCard(IdCard idCard) {
- this.idCard = idCard;
- }
- }
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>
- <class name="com.i51pro.hibernate.IdCard" table="t_idcard">
- <id name="id">
- <generator class="native"/>
- </id>
- <property name="cardNo"/>
- <one-to-one name="person" property-ref="idCard" />
- </class>
- </hibernate-mapping>
Person.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>
- <class name="com.i51pro.hibernate.Person" table="t_person">
- <id name="id">
- <generator class="native" />
- </id>
- <property name="name"/>
- <many-to-one name="idCard" unique="true" />
- </class>
- </hibernate-mapping>
4.编写hibernate映射文件,代码如下:
hibernate.cfg.xml
- <!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="hibernate.connection.url">jdbc:mysql://localhost/hibernate_one2one_ufk_2</property>
- <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
- <property name="hibernate.connection.username">root</property>
- <property name="hibernate.connection.password">admin</property>
- <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
- <property name="hibernate.show_sql">true</property>
- <mapping resource="com/i51pro/hibernate/Person.hbm.xml"/>
- <mapping resource="com/i51pro/hibernate/IdCard.hbm.xml"/>
- </session-factory>
- </hibernate-configuration>
5.在项目下新建一个SourceFolder,命名为test,在该包下编写单元测试类One2OneTest,进行单元测试,它的代码如下:
One2OneTest.java
- package com.i51pro.hibernate;
- import org.hibernate.Session;
- import org.hibernate.Transaction;
- import junit.framework.TestCase;
- public class One2OneTest extends TestCase {
- public void testSave1() {
- Session session = null;
- try {
- session = HibernateUtils.getSession();
- Transaction tx = session.beginTransaction();
- IdCard idCard = new IdCard();
- idCard.setCardNo("88888888");
- Person person = new Person();
- person.setName("李小晚");
- person.setIdCard(idCard);
- //不能保存,因为idCard是Transident状态
- session.save(person);
- session.getTransaction().commit();
- }catch(Exception e) {
- e.printStackTrace();
- session.getTransaction().rollback();
- }finally {
- HibernateUtils.closeSession(session);
- }
- }
- public void testSave2() {
- Session session = null;
- try {
- session = HibernateUtils.getSession();
- Transaction tx = session.beginTransaction();
- IdCard idCard = new IdCard();
- idCard.setCardNo("88888888");
- session.save(idCard);
- Person person = new Person();
- person.setName("李小晚");
- person.setIdCard(idCard);
- session.save(person);
- session.getTransaction().commit();
- }catch(Exception e) {
- e.printStackTrace();
- session.getTransaction().rollback();
- }finally {
- HibernateUtils.closeSession(session);
- }
- }
- public void testLoad1() {
- Session session = null;
- try {
- session = HibernateUtils.getSession();
- Transaction tx = session.beginTransaction();
- Person person = (Person)session.load(Person.class, 2);
- System.out.println("person.name:" + person.getName() );
- System.out.println("idCard.name:" + person.getIdCard().getCardNo());
- session.getTransaction().commit();
- }catch(Exception e) {
- e.printStackTrace();
- session.getTransaction().rollback();
- }
- }
- public void testLoad2() {
- Session session = null;
- try {
- session = HibernateUtils.getSession();
- Transaction tx = session.beginTransaction();
- IdCard idCard= (IdCard)session.load(IdCard.class, 1);
- System.out.println("idCard.name:" + idCard.getCardNo());
- System.out.println("person.name:" + idCard.getPerson().getName());
- session.getTransaction().commit();
- }catch(Exception e) {
- e.printStackTrace();
- session.getTransaction().rollback();
- }
- }
- }
总结:hibernate一对一唯一外键关联映射(双向关联Person<---->IdCard)
一对一唯一外键关联双向,需要在另一端(idcard),添加<one-to-one>标签,指示hibernate如何加载
其关联对象,默认根据主键加载person,外键关联映射中,因为两个实体采用的是person的外键维护的关系,
所以不能指定主键加载person,而要根据person的外键加载,所以采用如下映射方式:
<one-to-one name="person" property-ref="idCard"/>
hibernate一对一主键唯一外键关联(二)相关推荐
- hibernate一对一主键唯一外键关联(一)
1.新建工程项目hibernate_one2one_ufk_1,添加hibernate所需Jar包和数据库驱动Jar包. 2.编写工具类HibernateUtils.java和ExportDB.jav ...
- hibernate one2one 唯一外键关联(双向关联)
hibernate的一对一唯一外键关联映射(双向关联 Person <------->IdCard) 一对一唯一外键关联采用<one - to -one>标签映射,必须指定标签 ...
- hibernate一对一主键关联映射(一)---单向关联
1.新建工程项目hibernate_one2one_pk_1,添加hibernate所需Jar包和mysql驱动Jar包. 2.建立工具类HihernateUtils.java和ExportDB.ja ...
- 数据表的字段约束:主键、外键、唯一
一.主键:标记数据唯一非空,一个表最多只能有一个主键. CREATE TABLE products (product_no integer PRIMARY KEY, --主键约束,保证唯一且非空.-- ...
- MySQL的几个概念:主键,外键,索引,唯一索引
一.概念: 1.主键(primary key) 能够唯一标识表中某一行的属性或属性组.一个表只能有一个主键,但可以有多个候选索引.主键常常与外键构成参照完整性约束,防止出现数据不一致.主键可以保证记录 ...
- 将一张表的主键作为外键关联到另一张表中
将一张表的主键作为外键关联到另一张表中 1.外键的介绍 2.使用Navicat创建外键 3.外键的维护关系设定及其选择 1.外键的介绍 设置外键的作用很明显,就是讲两个表的数据产生关联,就比如个人信息 ...
- MySQL设置主键、联合主键、外键、唯一约束、非空约束、默认约束
MySQL登录.查看记录等基本操作 MySQL设置表的属性值自动增加 auto_increment 1.主键.联合主键.外键 1.什么是主键 主键是在多条记录中用于确定一条记录时使用的标识符.主键具备 ...
- 约束条件之主键与外键
文章目录 约束条件之主键 约束条件之外键 外键约束的创建 表关系之多对多 表关系之一对一 表关系之一对多 今日作业 书籍表与出版社表(多对多) 学生表与班级表(一对多) 老师表与课程表(一对一) 课程 ...
- SQL的主键和外键约束
SQL的主键和外键的作用: 外键取值规则:空值或参照的主键值. (1)插入非空值时,如果主键表中没有这个值,则不能插入. (2)更新时,不能改为主键表中没有的值. (3)删除主键表记录时,你可以在建外 ...
最新文章
- 5G 信令流程 — 5GC 的业务请求(Service Request)
- CSS 伪类与伪元素
- UNITY2018 真机开启deepprofiling的操作
- 大剑无锋之new一个对象背后发生了什么?
- nametuple用法(转)
- abs期刊分类2020_收藏:中科院期刊最新分区来了!| 附516本生物医学等五大领域一区汇总...
- 【LoadRunner技术讲座8】LoadRunner函数中的几个陷阱
- java拼接sql字符串
- Keil C51 Code Banking
- linux pack文件镜像,使用buildpack-deps 构建自己的入容器镜像
- 常微分方程——一阶微分方程的初等解法
- 河北省计算机科学专业高校排名,河北省计算机类专业大学排名
- [ROS Navigation Tuning Guide]翻译
- java 百万数据查询_JAVA技巧:Java中的大量数据查询
- 一篇个人原厂的非主流火星文
- 在 Windows Server 2003 企业服务器中如何配置 IPv6 协议
- m4s格式转换mp3_怎么把腾讯缓存的视频转换成MP3格式
- 运行mysql时,提示Table ‘performance_schema.session_variables’ doesn’t exis
- 如何计算机车启动牵引力,高中物理机车启动的两种方式分析
- mysql注入单引号被过滤_避开sql注入过滤的几个方法
热门文章
- Au入门系列之一:认识 Audition
- 2021腾讯社招java技术岗面试题
- 限流对于抖音玩家来说,无异于被宣布了“死亡”。
- etc通行费发票怎么打印?通行费发票打印步骤
- 一图秒懂 - MD文件语法标签,最简单的markdown入门
- markdown符号使用
- pjsip 设置麦克风语音输入量 扬声器播放
- python编辑程序、根据输入的百分制数_输入一个百分制成绩,利用switch语句编写程序,要求输出成绩等级A B C D,E。90以上为A...
- 家谱文化研究②:比赘婿更不光彩的家庭角色?何雨柱还乐在其中
- 烤仔建工 | Wearable Dao时装秀倒计时!在元宇宙里穿上“中国红”!