一對(duì)一關(guān)聯(lián)保存:
說(shuō)明: 留言狀態(tài)表: 記錄用戶的留言信息,如留言人openid,留言時(shí)間等…(主表)
用戶留言內(nèi)容表: 記錄用戶的留言內(nèi)容,id與狀態(tài)表一對(duì)一(從表)
留言表實(shí)體類配置:(主表)
添加一對(duì)一關(guān)聯(lián)的從表
1
2
|
// one to one private com.rhtcms.cms.entity.main.CustomerMessageContent customerMessageContent; //對(duì)應(yīng)內(nèi)容表信息 |
留言內(nèi)容表配置:(從表)
添加一對(duì)一關(guān)聯(lián)的主表:
1
2
|
//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 的從表
1
2
|
< 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 的主表
1
2
3
4
5
|
< 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剛剛保存的主表,然后再保存從表
1
2
3
4
5
6
7
|
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)名要素有 ,電話,姓名,門(mén)票id依據(jù)…(從表)
活動(dòng)表實(shí)體類配置:(主表)
1.添加自定義報(bào)名信息從表
1
|
private Set<ActivitySign> signs = new HashSet<ActivitySign>(); |
自定義報(bào)名要素實(shí)體類配置:(從表)
1.添加關(guān)聯(lián)的活動(dòng)表實(shí)體類
1
|
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)名信息從表
1
2
3
4
5
6
|
< 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ì)一字段
1
2
3
4
|
< 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è)置主表,然后再保存從表
1
2
3
4
5
6
7
8
|
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)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!
原文鏈接:https://blog.csdn.net/weixin_44980116/article/details/113033158