mybatis通過中間表實(shí)現(xiàn)一對多查詢功能
需求:
通過一個(gè)學(xué)生的id查詢出該學(xué)生所學(xué)的所有科目。
使用到的表格:
1.student:學(xué)生表

2.subject:科目表

3.stu_sub:學(xué)生-科目表(這里的成績字段沒用到,不用管)

實(shí)體類( get、set方法省略):
1.student
public class Student implements Serializable {
private int id;
private String stuNum; //學(xué)號
private String password;
private String stuName;
private String grade; //年級
private String department; //系
private String professional; //專業(yè)
private List<Subject> subList; //修讀課程
}
2.subject
public class Subject implements Serializable {
private Integer id;
private String subjectName;
}
首先記一次錯(cuò)誤的實(shí)踐:
最開始的想法很美好,思路示例如下:
首先通過stu_sub語句塊在中間表查詢出學(xué)生id對應(yīng)的subId,在通過resultMap里面的collection標(biāo)簽將subId傳到stu_sub_1語句塊中,實(shí)現(xiàn)聯(lián)級查詢。

結(jié)果:
可以查詢出該學(xué)生對應(yīng)的所有科目,但是無法封裝到student實(shí)體類的List<subject.>屬性中,會(huì)報(bào)錯(cuò)期望的返回值是1,但結(jié)果是n。
原因:
mybatis若是沒有用主鍵來查詢對多關(guān)系,就會(huì)把查詢出來的多個(gè)結(jié)果當(dāng)成多個(gè)對象來封裝。如上述例子,第一步通過stu_sub語句塊查詢出來的結(jié)果為:

這時(shí)候由于resultMap的type是student類型,所以mybatis會(huì)把上述的4個(gè)stuId當(dāng)成四個(gè)對象來存放collection查詢出來的科目。但我們方法的返回值是Student,所以會(huì)因?yàn)闊o法存放4個(gè)student而報(bào)錯(cuò)。
-------------------------------------------------------------分割線----------------------------------------------------------------
下面是成功實(shí)現(xiàn)的示例:
直接使用left join語句將三個(gè)表關(guān)聯(lián)查詢,再通過resultMap將我們所需要的學(xué)科注入到student對象中。xml代碼實(shí)現(xiàn)如下:
<resultMap id="Map_stu_sub" type="student">
<id column="id" property="id"></id>
<result column="stuNum" property="stuNum"></result>
<result column="stuName" property="stuName"></result>
<result column="grade" property="grade"></result>
<result column="department" property="department"></result>
<result column="professional" property="professional"></result>
<collection property="subList" ofType="subject">
<!--將subject的id改成其他別名,不然會(huì)跟student的id字段沖突-->
<id column="sub_id" property="id"></id>
<result column="subjectName" property="subjectName"></result>
</collection>
</resultMap>
<select id="stu_sub" resultMap="Map_stu_sub">
SELECT a.*,c.id as sub_id,c.subjectName FROM student a LEFT OUTER JOIN stu_sub b ON a.id=b.stuId LEFT JOIN SUBJECT c ON b.subId=c.id WHERE a.id = #{id}
</select>
然后直接調(diào)用stu_sub方法即可。
到此這篇關(guān)于mybatis通過中間表實(shí)現(xiàn)一對多查詢的文章就介紹到這了,更多相關(guān)mybatis一對多查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java大話之創(chuàng)建型設(shè)計(jì)模式教程示例
這篇文章主要為大家介紹了java大話之創(chuàng)建型設(shè)計(jì)模式教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
詳解Spring關(guān)于@Resource注入為null解決辦法
這篇文章主要介紹了詳解Spring關(guān)于@Resource注入為null解決辦法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
Java設(shè)計(jì)模式之組合模式(Composite模式)介紹
這篇文章主要介紹了Java設(shè)計(jì)模式之組合模式(Composite模式)介紹,Composite定義:將對象以樹形結(jié)構(gòu)組織起來,以達(dá)成“部分-整體” 的層次結(jié)構(gòu),使得客戶端對單個(gè)對象和組合對象的使用具有一致性,需要的朋友可以參考下2015-03-03
解決maven中只有Lifecycle而Dependencies和Plugins消失的問題
這篇文章主要介紹了maven中只有Lifecycle而Dependencies和Plugins消失的問題及解決方法,本文通過圖文的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-07-07
Java Scanner的使用和hasNextXXX()的用法說明
這篇文章主要介紹了Java Scanner的使用和hasNextXXX()的用法說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-10-10
淺析Java中JNI靜態(tài)注冊和動(dòng)態(tài)注冊
這篇文章主要為大家詳細(xì)介紹了Java中JNI靜態(tài)注冊和動(dòng)態(tài)注冊的相關(guān)知識,文中的示例代碼簡潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-12-12
Mybatis的TypeHandler加解密數(shù)據(jù)實(shí)現(xiàn)
在我們數(shù)據(jù)庫中有些時(shí)候會(huì)保存一些用戶的敏感信息,所以就需要對這些數(shù)據(jù)進(jìn)行加密,那么本文就介紹了Mybatis的TypeHandler加解密數(shù)據(jù)實(shí)現(xiàn),感興趣的可以了解一下2021-06-06

