mybatis通過中間表實現(xiàn)一對多查詢功能
需求:
通過一個學生的id查詢出該學生所學的所有科目。
使用到的表格:
1.student:學生表
2.subject:科目表
3.stu_sub:學生-科目表(這里的成績字段沒用到,不用管)
實體類( 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; //專業(yè) private List<Subject> subList; //修讀課程 }
2.subject
public class Subject implements Serializable { private Integer id; private String subjectName; }
首先記一次錯誤的實踐:
最開始的想法很美好,思路示例如下:
首先通過stu_sub語句塊在中間表查詢出學生id對應(yīng)的subId,在通過resultMap里面的collection標簽將subId傳到stu_sub_1語句塊中,實現(xiàn)聯(lián)級查詢。
結(jié)果:
可以查詢出該學生對應(yīng)的所有科目,但是無法封裝到student實體類的List<subject.>屬性中,會報錯期望的返回值是1,但結(jié)果是n。
原因:
mybatis若是沒有用主鍵來查詢對多關(guān)系,就會把查詢出來的多個結(jié)果當成多個對象來封裝。如上述例子,第一步通過stu_sub語句塊查詢出來的結(jié)果為:
這時候由于resultMap的type是student類型,所以mybatis會把上述的4個stuId當成四個對象來存放collection查詢出來的科目。但我們方法的返回值是Student,所以會因為無法存放4個student而報錯。
-------------------------------------------------------------分割線----------------------------------------------------------------
下面是成功實現(xiàn)的示例:
直接使用left join語句將三個表關(guān)聯(lián)查詢,再通過resultMap將我們所需要的學科注入到student對象中。xml代碼實現(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改成其他別名,不然會跟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通過中間表實現(xiàn)一對多查詢的文章就介紹到這了,更多相關(guān)mybatis一對多查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot整合flyway實現(xiàn)步驟解析
這篇文章主要介紹了SpringBoot整合flyway實現(xiàn)步驟解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-08-08springmvc處理模型數(shù)據(jù)Map過程解析
這篇文章主要介紹了springmvc處理模型數(shù)據(jù)Map過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-01-01