经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Hibernate » 查看文章
Hibernate的一对一,一对多/多对一关联保存的实现
来源:jb51  时间:2021/9/6 10:17:57  对本文有异议

一对一关联保存:

说明: 留言状态表: 记录用户的留言信息,如留言人openid,留言时间等…(主表)
用户留言内容表: 记录用户的留言内容,id与状态表一对一(从表)

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

添加一对一关联的从表

  1. // one to one
  2. private com.rhtcms.cms.entity.main.CustomerMessageContent customerMessageContent;//对应内容表信息

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

添加一对一关联的主表:

  1. //one to one
  2. private com.rhtcms.cms.entity.main.CustomerMessage customerMessage;//对应客户留言状态表

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

1.主表id采用uuid随机生成
2.设置one-to-one 的从表

  1. <id name="id" type="string" column="id"><generator class = "uuid"/></id>
  2. <one-to-one name="customerMessageContent" class="CustomerMessageContent" cascade="all"></one-to-one>

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

1.主键生成策略使用:foreign 使用另外一个相关联的对象的主键作为该对象主键。主要用于一对一关系中。
2.设置one-to-one 的主表

  1. <id name="messageId" type="string" column="message_id">
  2. <generator class="foreign"><param name="property">customerMessage</param></generator>
  3. </id>
  4. <one-to-one name="customerMessage" class="CustomerMessage" constrained="true" ></one-to-one>

保存方法:
思路:1.保存时先set主表数据,先将主表保存
2: set从表数据,其中关键一步,从表须set刚刚保存的主表,然后再保存从表

  1. CustomerMessage customerMessageSave = mng.save(customerMessage); //保存状态表信息,并获取uuid
  2. CustomerMessageContent customerMessageContent = new CustomerMessageContent();
  3. //首先对留言,反馈信息进行敏感词过滤
  4. String wordCensor = cmsMng.replaceSensitivity(questionText);
  5. customerMessageContent.setQuestionText(wordCensor);//设置内容表内容
  6. customerMessageContent.setCustomerMessage(customerMessageSave);//设置从表中主表的属性
  7. contentMng.save(customerMessageContent);//同时保存内容表信息

一对多/多对一保存

说明:1.活动表:保存活动信息,记录活动报名的信息,如场景,主办方,报名时间…(主表)
2.自定义报名信息表,因为报名要素不确定性,eg: 报名要素有 ,电话,姓名,门票id依据…(从表)

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

1.添加自定义报名信息从表

  1. private Set<ActivitySign> signs = new HashSet<ActivitySign>();

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

1.添加关联的活动表实体类

  1. private Activity activity;//活动表信息

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

1.主键采用 "native"策略(hilo+identity+sequence三选一)
ps:根据底层数据库对自动生成标识符的能力来选择i dentity、sequence、hilo三种生成器中的一种,适合跨数据库平台开发
2.配置一对多的报名信息从表

  1. <id name="id" type="java.lang.Integer" column="activity_id"><generator class="native"/></id>
  2. <set name="signs" cascade="save-update" lazy="false">
  3. <cache usage="read-write"/>
  4. <key column="activity_id" />
  5. <one-to-many class="ActivitySign"/>
  6. </set>

报名信息表:(从表)

配置多对一: name:主表多对一的属性 ,class: 主表实体类 column: 多对一字段

  1. <id name="id" column="sign_id">
  2. <generator class="native"></generator>
  3. </id>
  4. <many-to-one name="activity" class="Activity" column="activity_id"></many-to-one>

保存方法:
保存思路
1:保存方法带两个参数: 参数1: 主表的数据 ;参数2: 从表的数据
2.实现层首先保存主表,然后再遍历从表,还是一样的,从表先设置主表,然后再保存从表

  1. activityMng.save(bean,set);
  2. //......下面是save方法
  3. bean = dao.save(bean);
  4. // update by 2021年1月23日10:36:56 zqy 优化保存接口
  5. for (ActivitySign activitySign : set) {
  6. activitySign.setActivity(bean);
  7. signDao.save(activitySign);
  8. }

到此这篇关于Hibernate的一对一,一对多/多对一关联保存的实现的文章就介绍到这了,更多相关Hibernate一对一,一对多/多对一内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号