亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

mybatis通過中間表實現一對多查詢功能

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

需求:通過一個學生的id查詢出該學生所學的所有科目。

使用到的表格:1.student:學生表

mybatis通過中間表實現一對多查詢功能

2.subject:科目表

mybatis通過中間表實現一對多查詢功能

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

mybatis通過中間表實現一對多查詢功能

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

public class Student implements Serializable { private int id; private String stuNum; //學號 private String password; private String stuName; private String grade; //年級 private String department; //系 private String professional; //專業 private List<Subject> subList; //修讀課程}

2.subject

public class Subject implements Serializable { private Integer id; private String subjectName; }

首先記一次錯誤的實踐:最開始的想法很美好,思路示例如下:首先通過stu_sub語句塊在中間表查詢出學生id對應的subId,在通過resultMap里面的collection標簽將subId傳到stu_sub_1語句塊中,實現聯級查詢。

mybatis通過中間表實現一對多查詢功能

結果:可以查詢出該學生對應的所有科目,但是無法封裝到student實體類的List<subject.>屬性中,會報錯期望的返回值是1,但結果是n。原因:mybatis若是沒有用主鍵來查詢對多關系,就會把查詢出來的多個結果當成多個對象來封裝。如上述例子,第一步通過stu_sub語句塊查詢出來的結果為:

mybatis通過中間表實現一對多查詢功能

這時候由于resultMap的type是student類型,所以mybatis會把上述的4個stuId當成四個對象來存放collection查詢出來的科目。但我們方法的返回值是Student,所以會因為無法存放4個student而報錯。

-------------------------------------------------------------分割線----------------------------------------------------------------下面是成功實現的示例:直接使用left join語句將三個表關聯查詢,再通過resultMap將我們所需要的學科注入到student對象中。xml代碼實現如下:

<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改成其他別名,不然會跟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>

然后直接調用stu_sub方法即可。

到此這篇關于mybatis通過中間表實現一對多查詢的文章就介紹到這了,更多相關mybatis一對多查詢內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 亚洲图色在线 | 中国一级毛片在线观看 | 瑟妃19禁福利视频在线看mp4 | 天天综合亚洲 | 亚洲精品久 | 久久精品免费全国观看国产 | 免费毛片无需任何播放器 | 黄网站在线播放视频免费观看 | 欧美三级a做爰在线观看 | 久久er精品视频 | 欧美成人黑人xx视频免费观看 | 精品在线99| 日本一级淫片a 免费播放口 | 国产黄色在线观看 | 久国产| 特黄a三级三级三级 | 国产三级在线免费观看 | 极品美女aⅴ高清在线观看 极品美女一级毛片 | 一区二区高清视频 | 国产乱人乱精一区二区视频密 | 国产成人精品美女在线 | www.污网站| 久久视频一区 | 露脸超嫩97后在线播放 | 麻豆国产精品有码在线观看 | 麻豆传媒2021精品传媒一区 | 国产福利一区二区 | 欧美成人午夜不卡在线视频 | 蜜桃视频成a人v在线 | 美国一级特色大黄 | 女人16一毛片 | 国产精品丝袜 | 丁香综合网 | 欧美黑人巨大白妞出浆 | 成人免费国产欧美日韩你懂的 | 网友自拍一区 | 91中文字幕在线观看 | 黄色网址在线播放 | 亚洲综合婷婷 | 国产精品国产三级在线专区 | 亚洲va欧美va国产 |