Hibernate之对象关系映射01一对一单向关联

2024-08-30 00:08

本文主要是介绍Hibernate之对象关系映射01一对一单向关联,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

hibernate映射关系有一对一、一对多、多对一、多对多;其中每一种又分单向和双向,主键和外键。需要配置实体类、实体类的映射文件,对应为数据库表间的关系;此篇先讲非注解方式的。

单向一对一:即在一个对象中存在另一个对象的引用,而在另一个对象中则不存在该对象的引用。

参考熔岩文章:http://lavasoft.blog.51cto.com/62575/39312

实体类文件

Person11tab.java

private int personId;
private String personName;
private int age;
private Address11tab address11tab;

Address11tab.java

private int addressId;
private String detailAddress;

表结构

-- 一对一单向关联的中间表
DROP TABLE IF EXISTS join_11tab;
CREATE TABLE join_11tab (person_id int(11) PRIMARY KEY,address_id int(11) UNIQUE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;-- 一对一单向关联人员表
DROP TABLE IF EXISTS person_11tab;
CREATE TABLE person_11tab (person_id int(11) PRIMARY KEY auto_increment,person_name varchar(20),age int(11) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;-- 一对一单向关联家庭住址表
DROP TABLE IF EXISTS address_11tab;
CREATE TABLE address_11tab (address_id int(11) PRIMARY KEY auto_increment,detail_address varchar(255) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8; -- 为 一对一单向关联的中间表 增加外键
ALTER TABLE join_11tab ADD CONSTRAINT fk_join_11tab_person FOREIGN KEY(person_id) REFERENCES person_11tab(person_id);
ALTER TABLE join_11tab ADD CONSTRAINT fk_join_11tab_address FOREIGN KEY(address_id) REFERENCES address_11tab(address_id);-- SELECT * FROM person_11tab;
-- SELECT * FROM address_11tab;
-- SELECT * FROM join_11tab;

配置文件

Person11tab.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><class name="com.ack.hibernateMapping.entity.Person11tab" table="person_11tab"><id name="personId" column="person_id"><generator class="identity"/></id><property name="personName" column="person_name"/><property name="age"/><!--使用join元素显式确定连接表--><join table="join_11tab"><key column="person_id"/><!--其中unique=“true”属性,将多对一确定为“1-1”--><many-to-one name="address11tab" column="address_id" unique="true"/></join></class>
</hibernate-mapping>

Address11tab.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><class name="com.ack.hibernateMapping.entity.Address11tab" table="address_11tab"><id name="addressId" column="address_id"><generator class="identity"/></id><property name="detailAddress" column="detail_address"/></class>
</hibernate-mapping>

别忘了在hibernate.cfg.xml中加入类的映射文件引用。

测试类,HibernateUtil参考可前面的文章

public class Test_pa_11tab {public static void main(String[] args) {Person11tab p1 = new Person11tab();p1.setPersonName("陈三");Address11tab add1 = new Address11tab();add1.setDetailAddress("丽水市莲都区");p1.setAddress11tab(add1);Session session = HibernateUtil.getCurrentSession();session.beginTransaction();session.save(p1);session.save(add1);session.getTransaction().commit();}
}

p1在add1前保存,sql语句如下:

insert into person_11tab(person_name, age) values(?, ?)
insert into join_11tab(address_id, person_id) values(?, ?)
insert into address_11tab(detail_address)  values(?)
update join_11tab set address_id=? where person_id=?

add1在p1前保存,sql语句如下:

insert into address_11tab(detail_address)  values(?)
insert into person_11tab(person_name, age) values(?, ?)
insert into join_11tab(address_id, person_id) values(?, ?)

只有add1保存,sql语句如下:

insert into address_11tab(detail_address)  values(?)

只有p1保存,sql语句如下:

insert into person_11tab(person_name, age) values(?, ?)
insert into join_11tab(address_id, person_id) values(?, ?)

报异常:org.hibernate.TransientObjectException: object references an unsaved transient instance - save the transient instance before flushing: com.ack.hibernate.hibernateMapping.entity.Address11tab.

因为需要根据p1的Person11tab对象获取Address11tab的add1去update join_11tab表,在p1中找不到对应的add1。

这篇关于Hibernate之对象关系映射01一对一单向关联的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1119243

相关文章

Java实现将byte[]转换为File对象

《Java实现将byte[]转换为File对象》这篇文章将通过一个简单的例子为大家演示Java如何实现byte[]转换为File对象,并将其上传到外部服务器,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言1. 问题背景2. 环境准备3. 实现步骤3.1 从 URL 获取图片字节数据3.2 将字节数组

mysql关联查询速度慢的问题及解决

《mysql关联查询速度慢的问题及解决》:本文主要介绍mysql关联查询速度慢的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql关联查询速度慢1. 记录原因1.1 在一次线上的服务中1.2 最终发现2. 解决方案3. 具体操作总结mysql

Javascript访问Promise对象返回值的操作方法

《Javascript访问Promise对象返回值的操作方法》这篇文章介绍了如何在JavaScript中使用Promise对象来处理异步操作,通过使用fetch()方法和Promise对象,我们可以从... 目录在Javascript中,什么是Promise1- then() 链式操作2- 在之后的代码中使

MyBatis的配置对象Configuration作用及说明

《MyBatis的配置对象Configuration作用及说明》MyBatis的Configuration对象是MyBatis的核心配置对象,它包含了MyBatis运行时所需的几乎所有配置信息,这个对... 目录MyBATis配置对象Configuration作用Configuration 对象的主要作用C

SpringBoot实现导出复杂对象到Excel文件

《SpringBoot实现导出复杂对象到Excel文件》这篇文章主要为大家详细介绍了如何使用Hutool和EasyExcel两种方式来实现在SpringBoot项目中导出复杂对象到Excel文件,需要... 在Spring Boot项目中导出复杂对象到Excel文件,可以利用Hutool或EasyExcel

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

Java对象和JSON字符串之间的转换方法(全网最清晰)

《Java对象和JSON字符串之间的转换方法(全网最清晰)》:本文主要介绍如何在Java中使用Jackson库将对象转换为JSON字符串,并提供了一个简单的工具类示例,该工具类支持基本的转换功能,... 目录前言1. 引入 Jackson 依赖2. 创建 jsON 工具类3. 使用示例转换 Java 对象为

python安装whl包并解决依赖关系的实现

《python安装whl包并解决依赖关系的实现》本文主要介绍了python安装whl包并解决依赖关系的实现,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录一、什么是whl文件?二、我们为什么需要使用whl文件来安装python库?三、我们应该去哪儿下

Java中对象的创建和销毁过程详析

《Java中对象的创建和销毁过程详析》:本文主要介绍Java中对象的创建和销毁过程,对象的创建过程包括类加载检查、内存分配、初始化零值内存、设置对象头和执行init方法,对象的销毁过程由垃圾回收机... 目录前言对象的创建过程1. 类加载检查2China编程. 分配内存3. 初始化零值4. 设置对象头5. 执行

Java中基于注解的代码生成工具MapStruct映射使用详解

《Java中基于注解的代码生成工具MapStruct映射使用详解》MapStruct作为一个基于注解的代码生成工具,为我们提供了一种更加优雅、高效的解决方案,本文主要为大家介绍了它的具体使用,感兴趣... 目录介绍优缺点优点缺点核心注解及详细使用语法说明@Mapper@Mapping@Mappings@Co