欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Mybatis中怎么實(shí)現(xiàn)關(guān)聯(lián)關(guān)系-創(chuàng)新互聯(lián)

本篇文章為大家展示了Mybatis中怎么實(shí)現(xiàn)關(guān)聯(lián)關(guān)系,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

創(chuàng)新互聯(lián)是專業(yè)的瀘溪網(wǎng)站建設(shè)公司,瀘溪接單;提供做網(wǎng)站、成都做網(wǎng)站,網(wǎng)頁設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行瀘溪網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!

三種關(guān)聯(lián)關(guān)系:一對(duì)多,一對(duì)一,多對(duì)多

兩種查詢方式:嵌套查詢,連接查詢(也可稱作:多表單獨(dú)查詢,多表連接查詢)

每一種關(guān)聯(lián)關(guān)系都可以通過嵌套查詢和連接查詢來實(shí)現(xiàn)。

嵌套查詢相當(dāng)于進(jìn)行了兩次查詢,而連接查詢將兩張表連接然后再進(jìn)行查詢,這樣只進(jìn)行了一次查詢

由于數(shù)據(jù)表要對(duì)實(shí)體類進(jìn)行映射,所以每一種關(guān)聯(lián)關(guān)系中都需要在java類中定義屬性來進(jìn)行關(guān)聯(lián),可以通過如圖關(guān)聯(lián):

一對(duì)一查詢

數(shù)據(jù)表實(shí)現(xiàn):通過A表的主鍵引用B表的主鍵作為外鍵,就是說在A中主鍵和外鍵同一字段。

查詢方式:嵌套查詢,連接查詢;

關(guān)系:丈夫和妻子(Husband Wife)

嵌套查詢實(shí)現(xiàn):

在實(shí)體類husband中關(guān)聯(lián)wife,進(jìn)行連接查詢之后,需要使用resultMap對(duì)查出來的結(jié)果進(jìn)行結(jié)果映射;

resultMap中type屬性指定映射的類型;id標(biāo)簽為主鍵,result為普通屬性;

association標(biāo)簽指定關(guān)聯(lián)一個(gè)類,property屬性是它在數(shù)據(jù)表中的屬性名,javaType是關(guān)聯(lián)屬性的java類型;

連接查詢實(shí)現(xiàn):

其中association標(biāo)簽中:

select屬性: 加載另外一個(gè)映射語句,可以加載這個(gè)屬性映射需要的復(fù)雜類型,(就是可以再加載指定的映射類型)

column屬性:用于給select傳遞參數(shù),可以將已經(jīng)獲取到的屬性值,傳遞給目標(biāo) select 語句作為參數(shù);

一對(duì)多查詢

數(shù)據(jù)表實(shí)現(xiàn):使用一個(gè)外鍵進(jìn)行關(guān)聯(lián),外鍵放在多方的表中;

關(guān)聯(lián)屬性:可以寫在一方的實(shí)體類中也可以寫在多方的實(shí)體類中;

  1. 寫在一方中,使用list或別的集合進(jìn)行關(guān)聯(lián)(一方找多方)  寫在多方中,定義關(guān)聯(lián)對(duì)象屬性(通過多方找一方)

以多表連接查詢?yōu)槔?/strong>

關(guān)系:一個(gè)國家對(duì)應(yīng)多個(gè)部長(zhǎng)

通過resultMap進(jìn)行結(jié)果映射,collection標(biāo)簽可以指定映射的集合,其中porperty屬性指定的是該關(guān)聯(lián)屬性的名稱,ofType指定的是集合里面的java類型,id,result標(biāo)簽同resultMap中的一樣是對(duì)集合里面的屬性進(jìn)行映射;

多表單獨(dú)查詢(嵌套查詢):

與一對(duì)一中類似,在resultMap的collection中聲明中元素類型,然后插入?yún)?shù),將查詢結(jié)果進(jìn)行映射;

自關(guān)聯(lián)查詢:

數(shù)據(jù)表:一張數(shù)據(jù)表中包含著所有的條目,條目之間為一對(duì)多的關(guān)系(一個(gè)欄目下面包含著多個(gè)欄目)

查詢方式:連接查詢(自己連接自己)和嵌套查詢(調(diào)用自身查詢)

以嵌套查詢?yōu)槔?/p>

這是通過父欄目查詢子欄目的自關(guān)聯(lián)查詢:

在resultMap中collection的select中調(diào)用原來的查詢語句進(jìn)行查詢,形成一個(gè)循環(huán)調(diào)用,一直到查詢到的子欄目為空的時(shí)候停止;最后對(duì)查詢結(jié)果進(jìn)行映射。

當(dāng)然,也可通過子欄目查找它的所有的父欄目;

多對(duì)多查詢

數(shù)據(jù)表:需要用一張中間表表示多對(duì)多的關(guān)系,這張中間表引入兩張表的主鍵作為外鍵;

查詢方式:

  1. 多表連接查詢,不需要定義中間表實(shí)體類  多表嵌套查詢,需要定義中間表實(shí)體類  多表復(fù)雜查詢,不需要定義中間表實(shí)體類,但是返回值是一個(gè)List;

多表嵌套查詢定義中間實(shí)體類:

由于兩張表之間分別單獨(dú)查詢,需要通過中間表查找關(guān)聯(lián)并使用resultMap進(jìn)行映射關(guān)系處理,resultMap需要指明映射的java的類,并在實(shí)體類中定義關(guān)聯(lián)屬性才可以得到關(guān)聯(lián)屬性的信息;簡(jiǎn)單來說:一張表查詢完之后想要得到另一張表的信息,實(shí)際上是通過中間表來進(jìn)行映射得到另一張表的信息的;

多表復(fù)雜查詢:通過一張表先和中間表進(jìn)行連接查詢,然后再查詢另一張表的信息;

復(fù)雜查詢返回值是一個(gè)List:

由于一張表先和中間表連接,而中間表是多對(duì)多的關(guān)系;所以得到一個(gè)一對(duì)多的List形式查詢結(jié)果;

上述內(nèi)容就是Mybatis中怎么實(shí)現(xiàn)關(guān)聯(lián)關(guān)系,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享名稱:Mybatis中怎么實(shí)現(xiàn)關(guān)聯(lián)關(guān)系-創(chuàng)新互聯(lián)
轉(zhuǎn)載來源:http://chinadenli.net/article20/hphjo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管網(wǎng)站內(nèi)鏈網(wǎng)站設(shè)計(jì)Google自適應(yīng)網(wǎng)站軟件開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)