Hibernate的一對(duì)一,一對(duì)多/多對(duì)一關(guān)聯(lián)保存的實(shí)現(xiàn)
一對(duì)一關(guān)聯(lián)保存:
說(shuō)明: 留言狀態(tài)表: 記錄用戶的留言信息,如留言人openid,留言時(shí)間等…(主表)
用戶留言內(nèi)容表: 記錄用戶的留言內(nèi)容,id與狀態(tài)表一對(duì)一(從表)
留言表實(shí)體類配置:(主表)
添加一對(duì)一關(guān)聯(lián)的從表
// one to one private com.rhtcms.cms.entity.main.CustomerMessageContent customerMessageContent;//對(duì)應(yīng)內(nèi)容表信息
留言內(nèi)容表配置:(從表)
添加一對(duì)一關(guān)聯(lián)的主表:
//one to one private com.rhtcms.cms.entity.main.CustomerMessage customerMessage;//對(duì)應(yīng)客戶留言狀態(tài)表
留言表hbm.xml配置:(主表)
1.主表id采用uuid隨機(jī)生成
2.設(shè)置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>
留言內(nèi)容表hbm.xml配置:(從表)
1.主鍵生成策略使用:foreign 使用另外一個(gè)相關(guān)聯(lián)的對(duì)象的主鍵作為該對(duì)象主鍵。主要用于一對(duì)一關(guān)系中。
2.設(shè)置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.保存時(shí)先set主表數(shù)據(jù),先將主表保存
2: set從表數(shù)據(jù),其中關(guān)鍵一步,從表須set剛剛保存的主表,然后再保存從表
CustomerMessage customerMessageSave = mng.save(customerMessage); //保存狀態(tài)表信息,并獲取uuid
CustomerMessageContent customerMessageContent = new CustomerMessageContent();
//首先對(duì)留言,反饋信息進(jìn)行敏感詞過(guò)濾
String wordCensor = cmsMng.replaceSensitivity(questionText);
customerMessageContent.setQuestionText(wordCensor);//設(shè)置內(nèi)容表內(nèi)容
customerMessageContent.setCustomerMessage(customerMessageSave);//設(shè)置從表中主表的屬性
contentMng.save(customerMessageContent);//同時(shí)保存內(nèi)容表信息
一對(duì)多/多對(duì)一保存
說(shuō)明:1.活動(dòng)表:保存活動(dòng)信息,記錄活動(dòng)報(bào)名的信息,如場(chǎng)景,主辦方,報(bào)名時(shí)間…(主表)
2.自定義報(bào)名信息表,因?yàn)閳?bào)名要素不確定性,eg: 報(bào)名要素有 ,電話,姓名,門票id依據(jù)…(從表)
活動(dòng)表實(shí)體類配置:(主表)
1.添加自定義報(bào)名信息從表
private Set<ActivitySign> signs = new HashSet<ActivitySign>();
自定義報(bào)名要素實(shí)體類配置:(從表)
1.添加關(guān)聯(lián)的活動(dòng)表實(shí)體類
private Activity activity;//活動(dòng)表信息
活動(dòng)表hbm.xml配置:(主表)
1.主鍵采用 "native"策略(hilo+identity+sequence三選一)
ps:根據(jù)底層數(shù)據(jù)庫(kù)對(duì)自動(dòng)生成標(biāo)識(shí)符的能力來(lái)選擇i dentity、sequence、hilo三種生成器中的一種,適合跨數(shù)據(jù)庫(kù)平臺(tái)開(kāi)發(fā)
2.配置一對(duì)多的報(bào)名信息從表
<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>
報(bào)名信息表:(從表)
配置多對(duì)一: name:主表多對(duì)一的屬性 ,class: 主表實(shí)體類 column: 多對(duì)一字段
<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:保存方法帶兩個(gè)參數(shù): 參數(shù)1: 主表的數(shù)據(jù) ;參數(shù)2: 從表的數(shù)據(jù)
2.實(shí)現(xiàn)層首先保存主表,然后再遍歷從表,還是一樣的,從表先設(shè)置主表,然后再保存從表
activityMng.save(bean,set);
//......下面是save方法
bean = dao.save(bean);
// update by 2021年1月23日10:36:56 zqy 優(yōu)化保存接口
for (ActivitySign activitySign : set) {
activitySign.setActivity(bean);
signDao.save(activitySign);
}
到此這篇關(guān)于Hibernate的一對(duì)一,一對(duì)多/多對(duì)一關(guān)聯(lián)保存的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Hibernate一對(duì)一,一對(duì)多/多對(duì)一內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Springboot-Starter造輪子之自動(dòng)鎖組件lock-starter實(shí)現(xiàn)
這篇文章主要為大家介紹了Springboot-Starter造輪子之自動(dòng)鎖組件lock-starter實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05
詳解json string轉(zhuǎn)換為java bean及實(shí)例代碼
這篇文章主要介紹了詳解json string轉(zhuǎn)換為java bean及實(shí)例代碼的相關(guān)資料,這里提供實(shí)例代碼幫助大家理解,需要的朋友可以參考下2017-07-07
如何解決executors線程池創(chuàng)建的線程不釋放的問(wèn)題
這篇文章主要介紹了如何解決executors線程池創(chuàng)建的線程不釋放的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
使用SpringBoot + Redis + Vue實(shí)現(xiàn)動(dòng)態(tài)路由加載頁(yè)面的示例代
在現(xiàn)代 Web 應(yīng)用開(kāi)發(fā)中,動(dòng)態(tài)路由加載能夠顯著提升應(yīng)用的靈活性和安全性,本文將深入探討如何利用 Spring Boot、Redis、Element UI 和 Vue 技術(shù)棧實(shí)現(xiàn)動(dòng)態(tài)路由加載,并通過(guò) Redis 生成和驗(yàn)證有效鏈接以實(shí)現(xiàn)頁(yè)面訪問(wèn)控制,需要的朋友可以參考下2024-09-09
SpringBoot數(shù)據(jù)訪問(wèn)的實(shí)現(xiàn)
本文主要介紹了SpringBoot數(shù)據(jù)訪問(wèn)的實(shí)現(xiàn),引入各種xxxTemplate,xxxRepository來(lái)簡(jiǎn)化我們對(duì)數(shù)據(jù)訪問(wèn)層的操作,感興趣的可以了解一下2023-11-11

