Mybatis中3種關(guān)聯(lián)關(guān)系的實現(xiàn)方法示例
三種關(guān)聯(lián)關(guān)系:一對多,一對一,多對多
兩種查詢方式:嵌套查詢,連接查詢(也可稱作:多表單獨查詢,多表連接查詢)
每一種關(guān)聯(lián)關(guān)系都可以通過嵌套查詢和連接查詢來實現(xiàn)。
嵌套查詢相當(dāng)于進行了兩次查詢,而連接查詢將兩張表連接然后再進行查詢,這樣只進行了一次查詢
由于數(shù)據(jù)表要對實體類進行映射,所以每一種關(guān)聯(lián)關(guān)系中都需要在java類中定義屬性來進行關(guān)聯(lián),可以通過如圖關(guān)聯(lián):
一對一查詢
數(shù)據(jù)表實現(xiàn):通過A表的主鍵引用B表的主鍵作為外鍵,就是說在A中主鍵和外鍵同一字段。
查詢方式:嵌套查詢,連接查詢;
關(guān)系:丈夫和妻子(Husband Wife)
嵌套查詢實現(xiàn):
在實體類husband中關(guān)聯(lián)wife,進行連接查詢之后,需要使用resultMap對查出來的結(jié)果進行結(jié)果映射;
resultMap中type屬性指定映射的類型;id標(biāo)簽為主鍵,result為普通屬性;
association標(biāo)簽指定關(guān)聯(lián)一個類,property屬性是它在數(shù)據(jù)表中的屬性名,javaType是關(guān)聯(lián)屬性的java類型;
連接查詢實現(xiàn):
其中association標(biāo)簽中:
select屬性: 加載另外一個映射語句,可以加載這個屬性映射需要的復(fù)雜類型,(就是可以再加載指定的映射類型)
column屬性:用于給select傳遞參數(shù),可以將已經(jīng)獲取到的屬性值,傳遞給目標(biāo) select 語句作為參數(shù);
一對多查詢
數(shù)據(jù)表實現(xiàn):使用一個外鍵進行關(guān)聯(lián),外鍵放在多方的表中;
關(guān)聯(lián)屬性:可以寫在一方的實體類中也可以寫在多方的實體類中;
- 寫在一方中,使用list或別的集合進行關(guān)聯(lián)(一方找多方)
- 寫在多方中,定義關(guān)聯(lián)對象屬性(通過多方找一方)
以多表連接查詢?yōu)槔?/strong>
關(guān)系:一個國家對應(yīng)多個部長
通過resultMap進行結(jié)果映射,collection標(biāo)簽可以指定映射的集合,其中porperty屬性指定的是該關(guān)聯(lián)屬性的名稱,ofType指定的是集合里面的java類型,id,result標(biāo)簽同resultMap中的一樣是對集合里面的屬性進行映射;
多表單獨查詢(嵌套查詢):
與一對一中類似,在resultMap的collection中聲明中元素類型,然后插入?yún)?shù),將查詢結(jié)果進行映射;
自關(guān)聯(lián)查詢:
數(shù)據(jù)表:一張數(shù)據(jù)表中包含著所有的條目,條目之間為一對多的關(guān)系(一個欄目下面包含著多個欄目)
查詢方式:連接查詢(自己連接自己)和嵌套查詢(調(diào)用自身查詢)
以嵌套查詢?yōu)槔?/p>
這是通過父欄目查詢子欄目的自關(guān)聯(lián)查詢:
在resultMap中collection的select中調(diào)用原來的查詢語句進行查詢,形成一個循環(huán)調(diào)用,一直到查詢到的子欄目為空的時候停止;最后對查詢結(jié)果進行映射。
當(dāng)然,也可通過子欄目查找它的所有的父欄目;
多對多查詢
數(shù)據(jù)表:需要用一張中間表表示多對多的關(guān)系,這張中間表引入兩張表的主鍵作為外鍵;
查詢方式:
- 多表連接查詢,不需要定義中間表實體類
- 多表嵌套查詢,需要定義中間表實體類
- 多表復(fù)雜查詢,不需要定義中間表實體類,但是返回值是一個List;
多表嵌套查詢定義中間實體類:
由于兩張表之間分別單獨查詢,需要通過中間表查找關(guān)聯(lián)并使用resultMap進行映射關(guān)系處理,resultMap需要指明映射的java的類,并在實體類中定義關(guān)聯(lián)屬性才可以得到關(guān)聯(lián)屬性的信息;簡單來說:一張表查詢完之后想要得到另一張表的信息,實際上是通過中間表來進行映射得到另一張表的信息的;
多表復(fù)雜查詢:通過一張表先和中間表進行連接查詢,然后再查詢另一張表的信息;
復(fù)雜查詢返回值是一個List:
由于一張表先和中間表連接,而中間表是多對多的關(guān)系;所以得到一個一對多的List形式查詢結(jié)果;
類似這樣一對多:
總結(jié):
實際上除了數(shù)據(jù)庫的知識以外,Mybatis中的關(guān)聯(lián)關(guān)系實現(xiàn),主要通過resultMap來實現(xiàn)的
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。
- Mybatis多表關(guān)聯(lián)查詢的實現(xiàn)(DEMO)
- Mybatis 一對多和多對一關(guān)聯(lián)查詢問題
- 深入淺出MyBatis中映射文件和實體類的關(guān)聯(lián)性
- 實例講解Java的MyBatis框架對MySQL中數(shù)據(jù)的關(guān)聯(lián)查詢
- MyBatis實踐之動態(tài)SQL及關(guān)聯(lián)查詢
- MyBatis學(xué)習(xí)教程(五)-實現(xiàn)關(guān)聯(lián)表查詢方法詳解
- MyBatis學(xué)習(xí)筆記(二)之關(guān)聯(lián)關(guān)系
- mybatis實現(xiàn)一對一關(guān)聯(lián)映射實例代碼
- mybatis多對多關(guān)聯(lián)實戰(zhàn)教程(推薦)
- mybatis實現(xiàn)表與對象的關(guān)聯(lián)關(guān)系_動力節(jié)點Java學(xué)院整理
相關(guān)文章
Java基于elasticsearch實現(xiàn)集群管理
這篇文章主要介紹了java基于elasticsearch實現(xiàn)集群管理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-02-02關(guān)于RabbitMQ的Channel默認(rèn)線程
這篇文章主要介紹了關(guān)于RabbitMQ的Channel默認(rèn)線程,通過jvm工具觀察rabbitmq的線程使用情況,發(fā)現(xiàn)生產(chǎn)者每發(fā)一條消息,消費者這邊就會創(chuàng)建一條線程,言下之意,一個channel當(dāng)消息來到時就會異步處理這些消息,需要的朋友可以參考下2023-09-09使用Sharding-JDBC對數(shù)據(jù)進行分片處理詳解
這篇文章主要介紹了使用Sharding-JDBC對數(shù)據(jù)進行分片處理詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-10-10Java數(shù)據(jù)結(jié)構(gòu)之簡單鏈表的定義與實現(xiàn)方法示例
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)之簡單鏈表的定義與實現(xiàn)方法,簡單描述了鏈接的概念、原理,并結(jié)合實例形式分析了java定義與使用鏈表的相關(guān)步驟與操作技巧,需要的朋友可以參考下2017-10-10