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!
推薦閱讀:
- Lombok使用@Tolerate實現沖突兼容問題
- Springboot引入hibernate配置自動建表並進行增刪改查操作
- Java Hibernate中的持久化類和實體類關系
- SpringDataJpa創建聯合索引的實現
- 關於@Entity和@Table註解的用法詳解