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

MyBatis中<collection>標(biāo)簽的多種用法

 更新時(shí)間:2025年04月02日 09:26:53   作者:愿你天黑有燈下雨有傘  
collection標(biāo)簽是處理一對多關(guān)系的關(guān)鍵工具,它能夠?qū)⒉樵兘Y(jié)果巧妙地映射到Java對象的集合屬性中,本文主要介紹了MyBatis中<collection>標(biāo)簽的多種用法,感興趣的可以了解一下

在 MyBatis 中,<collection> 標(biāo)簽是處理一對多(One-to-Many)關(guān)系的關(guān)鍵工具,它能夠?qū)⒉樵兘Y(jié)果巧妙地映射到 Java 對象的集合屬性中。以下是 <collection> 的不同用法及其示例,結(jié)合知識庫中的信息整理如下:

一、嵌套查詢(Nested Select)

通過 select 屬性引用另一個(gè) SQL 查詢,根據(jù)主表的某一列(如 id)作為參數(shù),查詢子表的集合數(shù)據(jù)。

特點(diǎn)

  • 每條主記錄會觸發(fā)一次子查詢(可能導(dǎo)致 N+1 問題)。

  • 適合數(shù)據(jù)量較小或需要遞歸查詢的場景。

示例代碼

<!-- 主表的resultMap -->
<resultMap id="UserMap" type="User">
    <id property="id" column="id"/>
    <result property="username" column="username"/>
    <!-- 集合屬性:permissions -->
    <collection 
        property="permissions" 
        ofType="Permission" 
        select="com.example.mapper.PermissionMapper.selectByUserId" 
        column="id"
    />
</resultMap>

<!-- 主表的查詢SQL -->
<select id="selectUser" resultMap="UserMap">
    SELECT id, username FROM users WHERE id = #{id}
</select>

<!-- 子查詢(PermissionMapper.xml) -->
<select id="selectByUserId" resultType="Permission">
    SELECT * FROM permissions WHERE user_id = #{id}
</select>

解釋

  • property="permissions" :映射到 User 類的 permissions 集合屬性。

  • ofType="Permission" :指定集合元素的類型。

  • select="..." :引用子查詢的 Mapper 方法。

  • column="id" :將主表的 id 作為參數(shù)傳遞給子查詢。

二、嵌套結(jié)果(Nested Results)

通過 column 和 ofType 直接映射 JOIN 查詢的結(jié)果,避免多次查詢數(shù)據(jù)庫。

特點(diǎn)

  • 通過 JOIN 一次性獲取所有數(shù)據(jù),減少查詢次數(shù)。

  • 需要處理重復(fù)數(shù)據(jù)(主表字段會被重復(fù),需通過 columnPrefix 區(qū)分)。

示例代碼

<!-- 主表的resultMap -->
<resultMap id="UserMap" type="User">
    <id property="id" column="user_id"/>
    <result property="username" column="username"/>
    <!-- 集合屬性:orders -->
    <collection 
        property="orders" 
        ofType="Order" 
        columnPrefix="order_"
    >
        <id property="orderId" column="order_id"/>
        <result property="amount" column="amount"/>
    </collection>
</resultMap>

<!-- 主表的查詢SQL(使用JOIN) -->
<select id="selectUserWithOrders" resultMap="UserMap">
    SELECT 
        u.id AS user_id, 
        u.username, 
        o.id AS order_id, 
        o.amount 
    FROM users u 
    LEFT JOIN orders o ON u.id = o.user_id 
    WHERE u.id = #{id}
</select>

解釋

  • columnPrefix="order_" :將子表字段名前綴(如 order_id)與主表字段區(qū)分開。

  • <collection> 內(nèi)部定義子表字段的映射規(guī)則。

  • 主表字段(如 user_id)和子表字段(如 order_id)通過別名區(qū)分。

三、遞歸查詢(Recursive Query)

用于構(gòu)建層級結(jié)構(gòu)(如樹形菜單、權(quán)限結(jié)構(gòu)),通過 <collection> 自引用實(shí)現(xiàn)遞歸。

特點(diǎn)

  • 通過 select 屬性引用自身或同級的查詢方法,形成遞歸調(diào)用。

  • 適用于組織結(jié)構(gòu)、分類樹等場景。

示例代碼

<!-- 處理樹形結(jié)構(gòu)的resultMap -->
<resultMap id="CategoryMap" type="Category">
    <id property="id" column="id"/>
    <result property="name" column="name"/>
    <result property="parentId" column="parent_id"/>
    <!-- 遞歸查詢子節(jié)點(diǎn) -->
    <collection 
        property="children" 
        ofType="Category" 
        select="selectCategoriesByParentId" 
        column="id"
    />
</resultMap>

<!-- 查詢父節(jié)點(diǎn)的子節(jié)點(diǎn) -->
<select id="selectCategoriesByParentId" resultMap="CategoryMap">
    SELECT * FROM categories WHERE parent_id = #{id}
</select>

解釋

  • column="id" :將當(dāng)前節(jié)點(diǎn)的 id 作為父節(jié)點(diǎn) ID 傳遞給子查詢。

  • <collection> 引用同一個(gè) Mapper 中的 selectCategoriesByParentId 方法,形成遞歸。

  • 直到?jīng)]有子節(jié)點(diǎn)時(shí)停止遞歸。

四、使用 column 傳遞多個(gè)參數(shù)

當(dāng)子查詢需要多個(gè)參數(shù)時(shí),可以通過表達(dá)式指定多個(gè)列。

語法

column="{param1=column1, param2=column2}"

示例代碼

<collection 
    property="items" 
    ofType="Item" 
    select="com.example.mapper.ItemMapper.selectItemsByUserAndDate" 
    column="{userId=id, date=createTime}"
/>

解釋

  • 子查詢 selectItemsByUserAndDate 需要兩個(gè)參數(shù):userId 和 date。

  • column 表達(dá)式將主表的 id 映射為 userId,createTime 映射為 date

五、javaType 和 ofType 的區(qū)別

  • ofType :必須指定,用于定義集合中元素的類型(如 Permission)。

  • javaType :可選,指定集合的類型(如 ArrayList)。若不指定,MyBatis 默認(rèn)使用 List。

示例

<!-- 顯式指定javaType -->
<collection 
    property="permissions" 
    javaType="ArrayList" 
    ofType="Permission" 
    select="..." 
    column="..."
/>

總結(jié):不同場景的適用性

場景推薦用法優(yōu)缺點(diǎn)
簡單的一對多關(guān)系嵌套查詢(select)簡單易用,但可能引發(fā) N+1 問題
需要 JOIN 一次性獲取數(shù)據(jù)嵌套結(jié)果(columnPrefix)減少查詢次數(shù),但需處理重復(fù)字段和復(fù)雜 SQL
樹形結(jié)構(gòu)(如菜單、分類)遞歸查詢(自引用)簡潔且可自動構(gòu)建層級,但需注意性能(尤其數(shù)據(jù)量大時(shí))
需要傳遞多個(gè)參數(shù)column 表達(dá)式靈活傳遞多個(gè)參數(shù),但需確保子查詢參數(shù)匹配

通過合理選擇 <collection> 的用法,可以高效地處理 MyBatis 中的一對多映射需求。

到此這篇關(guān)于MyBatis中<collection>標(biāo)簽的多種用法的文章就介紹到這了,更多相關(guān)MyBatis  collection標(biāo)簽內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Springboot整合quartz實(shí)現(xiàn)多個(gè)定時(shí)任務(wù)實(shí)例

    Springboot整合quartz實(shí)現(xiàn)多個(gè)定時(shí)任務(wù)實(shí)例

    這篇文章主要介紹了Springboot整合quartz實(shí)現(xiàn)多個(gè)定時(shí)任務(wù)代碼實(shí)例,Quartz?是一款功能強(qiáng)大的開源任務(wù)調(diào)度框架,幾乎可以集成到任何?Java?應(yīng)用程序中,Quartz?可用于創(chuàng)建簡單或復(fù)雜的任務(wù)調(diào)度,用以執(zhí)行數(shù)以萬計(jì)的任務(wù),需要的朋友可以參考下
    2023-08-08
  • Java如何利用線程池和Redis實(shí)現(xiàn)高效數(shù)據(jù)入庫

    Java如何利用線程池和Redis實(shí)現(xiàn)高效數(shù)據(jù)入庫

    文章介紹了如何利用線程池和Redis在高并發(fā)環(huán)境中實(shí)現(xiàn)高效的數(shù)據(jù)入庫,通過將數(shù)據(jù)首先存儲在Redis緩存中,然后利用線程池定期批量入庫處理,確保系統(tǒng)的性能和穩(wěn)定性,主要組件包括BatchDataStorageService、CacheService和RedisUtils等
    2025-02-02
  • SpringBoot中將@Bean方法解析為BeanDefinition詳解

    SpringBoot中將@Bean方法解析為BeanDefinition詳解

    這篇文章主要介紹了SpringBoot中將@Bean方法解析為BeanDefinition詳解,得到的BeanDefinition是ConfigurationClassBeanDefinition類型,會為BeanDefinition設(shè)置factoryMethodName,這意味著當(dāng)實(shí)例化這個(gè)bean的時(shí)候?qū)⒉捎霉S方法,需要的朋友可以參考下
    2023-12-12
  • Spring攔截器中注入Bean失敗解放方案詳解

    Spring攔截器中注入Bean失敗解放方案詳解

    這兩天遇到SpringBoot攔截器中Bean無法注入問題。下面介紹關(guān)于SpringBoot攔截器中Bean無法注入的問題解決方案,感興趣的朋友一起看看吧
    2022-06-06
  • MybatisPlus實(shí)現(xiàn)數(shù)據(jù)權(quán)限隔離的示例詳解

    MybatisPlus實(shí)現(xiàn)數(shù)據(jù)權(quán)限隔離的示例詳解

    Mybatis Plus對Mybatis做了無侵入的增強(qiáng),非常的好用,今天就給大家介紹它的其中一個(gè)實(shí)用功能:數(shù)據(jù)權(quán)限插件,感興趣的可以跟隨小編一起了解下
    2024-04-04
  • Java命令行運(yùn)行錯(cuò)誤之找不到或無法加載主類問題的解決方法

    Java命令行運(yùn)行錯(cuò)誤之找不到或無法加載主類問題的解決方法

    這篇文章主要給大家介紹了關(guān)于Java命令行運(yùn)行錯(cuò)誤之找不到或無法加載主類問題的解決方法,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-01-01
  • Java編程簡單應(yīng)用

    Java編程簡單應(yīng)用

    本文主要介紹了三個(gè)簡單Java小程序———1、HelloWorld(HelloWorld的來源);2、輸出個(gè)人信息3、輸出特殊圖案。具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • Java中繼承、多態(tài)、重載和重寫介紹

    Java中繼承、多態(tài)、重載和重寫介紹

    這篇文章主要介紹了Java中繼承、多態(tài)、重載和重寫介紹,需要的朋友可以參考下
    2014-07-07
  • JVM虛擬機(jī)性能監(jiān)控與故障處理工具介紹

    JVM虛擬機(jī)性能監(jiān)控與故障處理工具介紹

    這篇文章主要為大家介紹了JVM虛擬機(jī)性能監(jiān)控與故障處理工具介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-07-07
  • Jenkins初級使用過程中的異常處理

    Jenkins初級使用過程中的異常處理

    這篇文章主要為大家介紹了Jenkins初級使用過程中的異常處理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04

最新評論