hibernate多表操作實例代碼
多表操作之多對多關(guān)系簡介
思路就是:
- 在數(shù)據(jù)庫底層通過添加中間表來指定關(guān)聯(lián)關(guān)系。
- 在雙方的實體中添加一個保存對方的集合
- 在雙方的配置文件中使用set標(biāo)簽和many-to-many標(biāo)簽來進(jìn)行關(guān)聯(lián)關(guān)系的配置。即可完成!
- 調(diào)用Hibernate的相關(guān)的API,操作就行了。
需要注意的地方
- 首先是數(shù)據(jù)庫中表的創(chuàng)建
這里有一個小例子:
多對多的核心表,第三方表。table:
create table thrid( one_id int not null, two_id int not null, constranit FK_one_id froeign key(one_id) reference one(id_in_one), constraint FK_two_id foreign key(two_id) reference two(id_in_two) );
這里就是將兩個表的主鍵作為了這個第三方的外鍵了。這樣可以方便關(guān)系的搭建。
- 然后是創(chuàng)建核心的Hibernate.cfg.cml文件,這里不再過多的闡述。
- 再就是創(chuàng)建相應(yīng)的符合數(shù)據(jù)庫中表結(jié)構(gòu)的JavaBean實體類。
遵守JavaBean的命名規(guī)范
有無參的構(gòu)造方法
屬性私有,以共有的setter和getter訪問
一定一定要記得包含多表中對方的一個集合set。
- 創(chuàng)建XX.hbm.xml映射文件:
這個映射文件可謂是Hibernate的核心所在了。注意這個文件要放到和實體類一個目錄下,也就是放到實體包中,這樣會比較好,方便查找和操作。
使用插件生成或者參照模板進(jìn)行修改。最核心的就是set標(biāo)簽及內(nèi)部的many-to-many標(biāo)簽了,如下:
employees 映射文件配置(多)
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="cn.itcast.h_hbm_oneToMany"> <class name="Employee" table="employee"> <id name="id"> <generator class="native"></generator> </id> <property name="name"></property> <!-- department屬性,Department類型,表示Employee與Department的多對一 --> <many-to-one name="department" column="departmentId" class="Department"></many-to-one> </class> </hibernate-mapping>
以及 department 映射文件配
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="cn.itcast.h_hbm_oneToMany"> <class name="Department" table="department"> <id name="id"> <generator class="native"></generator> </id> <property name="name"></property> <!-- employees屬性,Set集合,表達(dá)的是Department與Employee的一對多 inverse屬性:true表示自己是否放棄維護(hù)關(guān)聯(lián)關(guān)系,默認(rèn)為false。 --> <set name="employees" inverse="true"> <key column="departmentId"></key> <one-to-many class="Employee"/> </set> </class> </hibernate-mapping>
總結(jié)
配置完以上幾步,我們就可以正常的編寫我們的“DAO”層代碼了,但是由于有了Hibernate的Session這個神器,我們需要做的也就是在DAO層中進(jìn)行相關(guān)的API的調(diào)用。這將是非常非常的簡單以及輕松的一項任務(wù)。
以上就是本文關(guān)于hibernate多表操作實例代碼的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
SpringBoot整合Echarts實現(xiàn)用戶人數(shù)和性別展示功能(詳細(xì)步驟)
這篇文章主要介紹了SpringBoot整合Echarts實現(xiàn)用戶人數(shù)和性別展示,通過數(shù)據(jù)庫設(shè)計、實現(xiàn)數(shù)據(jù)訪問層、業(yè)務(wù)邏輯層和控制層的代碼編寫,以及前端頁面的開發(fā),本文詳細(xì)地介紹了SpringBoot整合Echarts的實現(xiàn)步驟和代碼,需要的朋友可以參考下2023-05-05SpringBoot2整合activiti6環(huán)境搭建過程解析
這篇文章主要介紹了SpringBoot2整合activiti6環(huán)境搭建過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-11-11