Hibernate的一对一,一对多/多对一关联保存的实现

作者:纵有千千星晚 时间:2022-03-13 12:41:08 

目录
  • 一对一关联保存:

    • 留言表实体类配置:(主表)

    • 留言内容表配置:(从表)

    • 留言表hbm.xml配置:(主表)

    • 留言内容表hbm.xml配置:(从表)

  • 一对多/多对一保存

    • 活动表实体类配置:(主表)

    • 自定义报名要素实体类配置:(从表)

    • 活动表hbm.xml配置:(主表)

    • 报名信息表:(从表)

一对一关联保存:

说明: 留言状态表: 记录用户的留言信息,如留言人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);
}

来源:https://blog.csdn.net/weixin_44980116/article/details/113033158

标签:Hibernate,一对一,一对多,多对一
0
投稿

猜你喜欢

  • Java SpringBoot整合shiro-spring-boot-starterqi项目报错解决

    2022-11-07 03:27:02
  • springboot集成mybatisplus的方法

    2022-08-02 16:35:12
  • Java创建与结束线程代码示例

    2023-01-16 16:20:00
  • Java程序员新手老手常用的八大开发工具

    2021-12-04 03:39:04
  • IDEA入门级使用教程你居然还在用eclipse?

    2022-03-27 07:35:19
  • java开发之Jdbc分页源码详解

    2021-10-28 16:06:48
  • Java实现远程控制技术完整源代码分享

    2022-04-10 20:31:53
  • Android 6.0动态权限申请教程

    2023-09-26 16:43:56
  • 分享15款Java程序员必备的开发工具

    2021-12-07 19:09:07
  • 详解SpringMVC @RequestBody接收Json对象字符串

    2022-03-20 05:00:10
  • Java 反射类型Type的用法说明

    2023-01-23 04:15:44
  • 解决WPF附加属性的Set函数不调用的问题

    2022-09-27 09:52:38
  • Java设计模式之访问者模式使用场景及代码示例

    2021-06-27 13:34:25
  • FeignClient中name和url属性的作用说明

    2023-06-04 13:21:55
  • 解决Swagger2返回map复杂结构不能解析的问题

    2022-07-15 09:17:04
  • MyBatis-Plus多表联查的实现方法(动态查询和静态查询)

    2023-11-23 22:26:45
  • SpringMVC框架整合Junit进行单元测试(案例详解)

    2022-04-10 20:53:37
  • Flutter实现矩形取色器的封装

    2023-06-19 04:08:47
  • Java 数据结构与算法系列精讲之排序算法

    2023-11-01 13:25:40
  • 浅谈MyBatis 事务管理

    2022-03-22 16:17:11
  • asp之家 软件编程 m.aspxhome.com