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一對一,一對多/多對一內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: