一對一關聯保存:
說明: 留言狀態表: 記錄用戶的留言信息,如留言人openid,留言時間等…(主表)
用戶留言內容表: 記錄用戶的留言內容,id與狀態表一對一(從表)
留言表實體類配置:(主表)
添加一對一關聯的從表
1
2
|
// one to one private com.rhtcms.cms.entity.main.CustomerMessageContent customerMessageContent; //對應內容表信息 |
留言內容表配置:(從表)
添加一對一關聯的主表:
1
2
|
//one to one private com.rhtcms.cms.entity.main.CustomerMessage customerMessage; //對應客戶留言狀態表 |
留言表hbm.xml配置:(主表)
1.主表id采用uuid隨機生成
2.設置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 > |
留言內容表hbm.xml配置:(從表)
1.主鍵生成策略使用:foreign 使用另外一個相關聯的對象的主鍵作為該對象主鍵。主要用于一對一關系中。
2.設置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.保存時先set主表數據,先將主表保存
2: set從表數據,其中關鍵一步,從表須set剛剛保存的主表,然后再保存從表
1
2
3
4
5
6
7
|
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.添加自定義報名信息從表
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
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 > |
報名信息表:(從表)
配置多對一: name:主表多對一的屬性 ,class: 主表實體類 column: 多對一字段
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:保存方法帶兩個參數: 參數1: 主表的數據 ;參數2: 從表的數據
2.實現層首先保存主表,然后再遍歷從表,還是一樣的,從表先設置主表,然后再保存從表
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 優化保存接口 for (ActivitySign activitySign : set) { activitySign.setActivity(bean); signDao.save(activitySign); } |
到此這篇關于Hibernate的一對一,一對多/多對一關聯保存的實現的文章就介紹到這了,更多相關Hibernate一對一,一對多/多對一內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://blog.csdn.net/weixin_44980116/article/details/113033158