欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis通過中間表實現(xiàn)一對多查詢功能

 更新時間:2021年08月06日 10:43:58   作者:哪來的大頭  
這篇文章主要介紹了mybatis通過中間表實現(xiàn)一對多查詢,通過一個學生的id查詢出該學生所學的所有科目,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下

需求:
通過一個學生的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)步驟解析

    這篇文章主要介紹了SpringBoot整合flyway實現(xiàn)步驟解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-08-08
  • JAVA通過XPath解析XML性能比較詳解

    JAVA通過XPath解析XML性能比較詳解

    本篇文章主要介紹了JAVA通過XPath解析XML性能比較詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • Java異常類型以及處理實例詳解

    Java異常類型以及處理實例詳解

    在程序設(shè)計中,進行異常處理是非常關(guān)鍵和重要的一部分,一個程序的異常處理框架的好壞直接影響到整個項目的代碼質(zhì)量以及后期維護成本和難度,這篇文章主要給大家介紹了關(guān)于Java異常類型以及處理的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • springmvc處理模型數(shù)據(jù)Map過程解析

    springmvc處理模型數(shù)據(jù)Map過程解析

    這篇文章主要介紹了springmvc處理模型數(shù)據(jù)Map過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-01-01
  • Java LinkedList源碼深入分析

    Java LinkedList源碼深入分析

    鏈表(Linkedlist)是一種常見的基礎(chǔ)數(shù)據(jù)結(jié)構(gòu),是一種線性表,但是并不會按線性的順序存儲數(shù)據(jù),而是在每一個節(jié)點里存到下一個節(jié)點的地址。鏈表可分為單向鏈表和雙向鏈表
    2022-08-08
  • springboot項目啟動慢的問題排查方式

    springboot項目啟動慢的問題排查方式

    這篇文章主要介紹了springboot項目啟動慢的問題排查方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Java探索之Feign入門使用詳解

    Java探索之Feign入門使用詳解

    這篇文章主要介紹了Java探索之Feign入門使用詳解,關(guān)于feign,我也是第一次遇到,于是在網(wǎng)上搜集了相關(guān)文章,這篇比較詳細,介紹了其簡介,選擇feign的原因以及其他相關(guān)內(nèi)容,需要的朋友可以參考下。
    2017-10-10
  • 比較常用UML類圖幾種關(guān)系的小結(jié)

    比較常用UML類圖幾種關(guān)系的小結(jié)

    本文給大家總結(jié)了UML類圖中幾種比較常用的關(guān)系小總結(jié),需要的朋友可以參考下
    2015-10-10
  • SpringBoot中@Import注解如何正確使用

    SpringBoot中@Import注解如何正確使用

    這篇文章主要介紹了SpringBoot中@Import注解的使用方式,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-06-06
  • Springboot如何解決前端請求跨域的問題

    Springboot如何解決前端請求跨域的問題

    這篇文章主要介紹了Springboot如何解決前端請求跨域的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07

最新評論