Hibernate的一对一,一对多/多对一关联保存的实现
一对一关联保存:
说明: 留言状态表: 记录用户的留言信息,如留言人openid,留言时间等…(主表)
用户留言内容表: 记录用户的留言内容,id与状态表一对一(从表)
留言表实体类配置:(主表)
添加一对一关联的从表
// one to one private com.rhtcms.cms.entity.main.CustomerMessageContent customerMessageContent;//对应内容表信息
留言内容表配置:(从表)
添加一对一关联的主表:
//one to one private com.rhtcms.cms.entity.main.CustomerMessage customerMessage;//对应客户留言状态表
留言表hbm.xml配置:(主表)
1.主表id采用uuid随机生成
2.设置one-to-one 的从表
<id name="id" type="string" column="id"><generator class = "uuid"/></id> <one-to-one name="customerMessageContent" class="CustomerMessageContent" cascade="all"></one-to-one>
留言内容表hbm.xml配置:(从表)
1.主键生成策略使用:foreign 使用另外一个相关联的对象的主键作为该对象主键。主要用于一对一关系中。
2.设置one-to-one 的主表
<id name="messageId" type="string" column="message_id"> <generator class="foreign"><param name="property">customerMessage</param></generator> </id> <one-to-one name="customerMessage" class="CustomerMessage" constrained="true" ></one-to-one>
保存方法:
思路:1.保存时先set主表数据,先将主表保存
2: set从表数据,其中关键一步,从表须set刚刚保存的主表,然后再保存从表
CustomerMessage customerMessageSave = mng.save(customerMessage); //保存状态表信息,并获取uuid CustomerMessageContent customerMessageContent = new CustomerMessageContent(); //首先对留言,反馈信息进行敏感词过滤 String wordCensor = cmsMng.replaceSensitivity(questionText); customerMessageContent.setQuestionText(wordCensor);//设置内容表内容 customerMessageContent.setCustomerMessage(customerMessageSave);//设置从表中主表的属性 contentMng.save(customerMessageContent);//同时保存内容表信息
一对多/多对一保存
说明:1.活动表:保存活动信息,记录活动报名的信息,如场景,主办方,报名时间…(主表)
2.自定义报名信息表,因为报名要素不确定性,eg: 报名要素有 ,电话,姓名,门票id依据…(从表)
活动表实体类配置:(主表)
1.添加自定义报名信息从表
private Set<ActivitySign> signs = new HashSet<ActivitySign>();
自定义报名要素实体类配置:(从表)
1.添加关联的活动表实体类
private Activity activity;//活动表信息
活动表hbm.xml配置:(主表)
1.主键采用 "native"策略(hilo+identity+sequence三选一)
ps:根据底层数据库对自动生成标识符的能力来选择i dentity、sequence、hilo三种生成器中的一种,适合跨数据库平台开发
2.配置一对多的报名信息从表
<id name="id" type="java.lang.Integer" column="activity_id"><generator class="native"/></id> <set name="signs" cascade="save-update" lazy="false"> <cache usage="read-write"/> <key column="activity_id" /> <one-to-many class="ActivitySign"/> </set>
报名信息表:(从表)
配置多对一: name:主表多对一的属性 ,class: 主表实体类 column: 多对一字段
<id name="id" column="sign_id"> <generator class="native"></generator> </id> <many-to-one name="activity" class="Activity" column="activity_id"></many-to-one>
保存方法:
保存思路
1:保存方法带两个参数: 参数1: 主表的数据 ;参数2: 从表的数据
2.实现层首先保存主表,然后再遍历从表,还是一样的,从表先设置主表,然后再保存从表
activityMng.save(bean,set); //......下面是save方法 bean = dao.save(bean); // update by 2021年1月23日10:36:56 zqy 优化保存接口 for (ActivitySign activitySign : set) { activitySign.setActivity(bean); signDao.save(activitySign); }
到此这篇关于Hibernate的一对一,一对多/多对一关联保存的实现的文章就介绍到这了,更多相关Hibernate一对一,一对多/多对一内容请搜索猪先飞以前的文章或继续浏览下面的相关文章希望大家以后多多支持猪先飞!
相关文章
Hibernate4在MySQL5.1以上版本创建表出错 type=InnDB
本文主要介绍解决Hibernate4在MySQL5.1自动创建表出错的方法,简单实用,需要的朋友可以参考下。...2016-06-12- 这篇文章主要介绍了Java web Hibernate如何与数据库链接,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-07-01
- 这篇文章主要介绍了Hibernate持久化对象生命周期原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-25
- 这篇文章主要介绍了Mybatis自关联查询一对多查询的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-01
Abp.NHibernate连接PostgreSQl数据库的方法
这篇文章主要为大家详细介绍了Abp.NHibernate连接PostgreSQl数据库的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2020-07-11- NHibernate 是一个基于.Net 的针对关系型数据库的对象持久化类库。下面这篇文章主要给大家介绍了关于如何在.NET Core应用中使用NHibernate的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下...2021-09-22
Mybatis使用@one和@Many实现一对一及一对多关联查询
本文主要介绍了Mybatis使用@one和@Many实现一对一及一对多关联查询,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-21- NHibernate的设计思想和Hibernate的设计思想基本相同,都是为了避免频繁的编写sql脚本,使用面向对象的方式使用hql语句进行查询。下面这篇文章主要给大家介绍了关于在C#项目中如何使用NHibernate的相关资料,需要的朋友可以参考借鉴,下面来一起学习学习吧。...2020-06-25
- 在本篇内容里小编给大家整理的是一篇关于java中Hibernate的状态总结内容,有兴趣的朋友们可以学习下。...2021-01-26
- 在本篇文章里小编给大家整理的是一篇关于java中Hibernate缓存形式总结内容,有兴趣的朋友们可以参考下。...2021-01-26
- 本文给大家介绍Mybatis结果集映射一对多简单入门教程,包括搭建数据库环境的过程,idea搭建maven项目的代码详解,本文通过实例代码给大家介绍的非常详细,需要的朋友参考下吧...2021-06-21
关于MyBatis 查询数据时属性中多对一的问题(多条数据对应一条数据)
这篇文章主要介绍了MyBatis 查询数据时属性中多对一的问题(多条数据对应一条数据),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-01-18在resin3.0中配置hibernate2.1.2连mysql
在resin3.0中配置hibernate2.1.2连mysql 在resin3.0中配置hibernate2.1.2连mysql Author : hamal 约定: resin3 代表resin3.0的安装根目录 hibernate2 代...2016-11-25- 本文主要介绍了Hibernate的一对一,一对多/多对一关联保存的实现,文中通过示例代码介绍的很详细,感兴趣的可以了解一下...2021-09-06
- 在本篇文章里小编给大家整理的是一篇关于java中mybatis和hibernate的用法总结内容,有兴趣的朋友们可以学习参考下。...2021-01-19
- 这篇文章主要介绍了hibernate 配置数据库方言的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-05-11
- 这篇文章主要介绍了解析Mybatis对sql表的一对多查询,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2022-06-13
- 这篇文章主要介绍了mybatis如何批量添加一对多中间表,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2022-02-28
Spring Boot 整合JPA 数据模型关联使用操作(一对一、一对多、多对多)
这篇文章主要介绍了Spring Boot 整合JPA 数据模型关联操作(一对一、一对多、多对多),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2022-07-19