成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

mybatis通過(guò)中間表實(shí)現(xiàn)一對(duì)多查詢功能

瀏覽:6日期:2023-10-18 10:59:34

需求:通過(guò)一個(gè)學(xué)生的id查詢出該學(xué)生所學(xué)的所有科目。

使用到的表格:1.student:學(xué)生表

mybatis通過(guò)中間表實(shí)現(xiàn)一對(duì)多查詢功能

2.subject:科目表

mybatis通過(guò)中間表實(shí)現(xiàn)一對(duì)多查詢功能

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

mybatis通過(guò)中間表實(shí)現(xiàn)一對(duì)多查詢功能

實(shí)體類( get、set方法省略):1.student

public class Student implements Serializable { private int id; private String stuNum; //學(xué)號(hào) private String password; private String stuName; private String grade; //年級(jí) 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í)踐:最開(kāi)始的想法很美好,思路示例如下:首先通過(guò)stu_sub語(yǔ)句塊在中間表查詢出學(xué)生id對(duì)應(yīng)的subId,在通過(guò)resultMap里面的collection標(biāo)簽將subId傳到stu_sub_1語(yǔ)句塊中,實(shí)現(xiàn)聯(lián)級(jí)查詢。

mybatis通過(guò)中間表實(shí)現(xiàn)一對(duì)多查詢功能

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

mybatis通過(guò)中間表實(shí)現(xiàn)一對(duì)多查詢功能

這時(shí)候由于resultMap的type是student類型,所以mybatis會(huì)把上述的4個(gè)stuId當(dāng)成四個(gè)對(duì)象來(lái)存放collection查詢出來(lái)的科目。但我們方法的返回值是Student,所以會(huì)因?yàn)闊o(wú)法存放4個(gè)student而報(bào)錯(cuò)。

-------------------------------------------------------------分割線----------------------------------------------------------------下面是成功實(shí)現(xiàn)的示例:直接使用left join語(yǔ)句將三個(gè)表關(guān)聯(lián)查詢,再通過(guò)resultMap將我們所需要的學(xué)科注入到student對(duì)象中。xml代碼實(shí)現(xiàn)如下:

<resultMap 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 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通過(guò)中間表實(shí)現(xiàn)一對(duì)多查詢的文章就介紹到這了,更多相關(guān)mybatis一對(duì)多查詢內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章: