亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

深入淺析MyBatis foreach標(biāo)簽

 更新時間:2021年09月29日 10:17:07   作者:JD強子  
Mybatis foreach 標(biāo)簽用于循環(huán)語句,它很好的支持了數(shù)據(jù)和 List、set 接口的集合,并對此提供遍歷的功能,本文給大家介紹MyBatis foreach標(biāo)簽的相關(guān)知識,感興趣的朋友一起看看吧

前面我們學(xué)習(xí)了如何使用 Mybatis if、where、trim 等動態(tài)語句來處理一些簡單的查詢操作。對于一些 SQL 語句中含有 in 條件,需要迭代條件集合來生成的情況,可以使用 foreach 來實現(xiàn) SQL 條件的迭代。

Mybatis foreach 標(biāo)簽用于循環(huán)語句,它很好的支持了數(shù)據(jù)和 List、set 接口的集合,并對此提供遍歷的功能。語法格式如下。

在這里插入圖片描述

SELECT * FROM product_ 
 	WHERE ID in
			<foreach item="item" index="index" collection="list"
    			open="(" separator="," close=")">
      		             #{item}
			</foreach>

如例,如圖查詢出id等于1,3,5的數(shù)據(jù)出來。

在這里插入圖片描述

foreach 標(biāo)簽主要有以下屬性,說明如下。

  • item:表示集合中每一個元素進行迭代時的別名。
  • index:指定一個名字,表示在迭代過程中每次迭代到的位置。
  • open:表示該語句以什么開始(既然是 in 條件語句,所以必然以(開始)。
  • separator:表示在每次進行迭代之間以什么符號作為分隔符(既然是 in 條件語句,所以必然以,作為分隔符)。
  • close:表示該語句以什么結(jié)束(既然是 in 條件語句,所以必然以)開始)。

使用 foreach 標(biāo)簽時,最關(guān)鍵、最容易出錯的是 collection 屬性,該屬性是必選的,但在不同情況下該屬性的值是不一樣的,主要有以下 3 種情況:

  • 如果傳入的是單參數(shù)且參數(shù)類型是一個 List,collection 屬性值為 list。
  • 如果傳入的是單參數(shù)且參數(shù)類型是一個 array 數(shù)組,collection 的屬性值為 array。
  • 如果傳入的參數(shù)是多個,需要把它們封裝成一個 Map,當(dāng)然單參數(shù)也可以封裝成 Map。Map 的 key 是參數(shù)名,collection 屬性值是傳入的 List 或 array 對象在自己封裝的 Map 中的 key。

在使用 foreach 標(biāo)簽時,應(yīng)提前預(yù)估一下 collection 對象的長度。因為大量數(shù)據(jù)的 in 語句會影響性能,且還有一些數(shù)據(jù)庫會限制執(zhí)行的 SQL 語句長度。

使用foreach元素查詢用戶信息

現(xiàn)有 website 表包含以下記錄。

+----+----------------+----------------------------+-----+---------+---------------------+
| id | name           | url                        | age | country | createtime          |
+----+----------------+----------------------------+-----+---------+---------------------+
|  1 | 編程幫         | https://www.biancheng.net/ |  10 | CN      | 2021-02-23 10:20:40 |
|  2 | C語言中文網(wǎng)    | http://c.biancheng.net/    |  12 | CN      | 2021-03-08 11:23:27 |
|  3 | 百度           | https://www.baidu.com/     |  18 | CN      | 2021-03-08 11:23:53 |
|  4 | 淘寶           | https://www.taobao.com/    |  17 | CN      | 2021-03-10 10:33:54 |
|  5 | Google         | https://www.google.com/    |  23 | US      | 2021-03-10 10:34:34 |
|  6 | GitHub         | https://github.com/        |  13 | US      | 2021-03-10 10:34:34 |
|  7 | Stack Overflow | https://stackoverflow.com/ |  16 | US      | 2021-03-10 10:34:34 |
|  8 | Yandex         | http://www.yandex.ru/      |  11 | RU      | 2021-03-10 10:34:34 |
+----+----------------+----------------------------+-----+---------+---------------------+

WebsiteMapper.xml 中代碼如下。

<!--使用foreach元素查詢用戶信息-->
<select id="selectWebsite"
    parameterType="net.biancheng.po.Website"
    resultType="net.biancheng.po.Website">
    SELECT id,name,url,age,country
    FROM website WHERE age in
    <foreach item="age" index="index" collection="list" open="("
        separator="," close=")">
        #{age}
    </foreach>
</select>

WebsiteMapper 類中相應(yīng)方法如下。

public List<Website> selectWebsite(List<Integer> ageList);

測試代碼如下。

public class Test {
    public static void main(String[] args) throws IOException {
        // 讀取配置文件mybatis-config.xml
        InputStream config = Resources.getResourceAsStream("mybatis-config.xml"); // 根據(jù)配置文件構(gòu)建
        SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(config);
        // 通過SqlSessionFactory創(chuàng)建SqlSession
        SqlSession ss = ssf.openSession();
        List<Integer> ageList = new ArrayList<Integer>();
        ageList.add(10);
        ageList.add(12);
        List<Website> siteList = ss.selectList("net.biancheng.mapper.WebsiteMapper.selectWebsite", ageList);
        for (Website ws : siteList) {
            System.out.println(ws);
        }
    }
}

輸出結(jié)果如下。

在這里插入圖片描述

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

相關(guān)文章

  • Spring創(chuàng)建IOC容器的方式解析

    Spring創(chuàng)建IOC容器的方式解析

    這篇文章主要介紹了Spring創(chuàng)建IOC容器的方式解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-10-10
  • SpringBoot中的@Conditional?注解的使用

    SpringBoot中的@Conditional?注解的使用

    @Conditional是Spring4新提供的注解,它的作用是按照一定的條件進行判斷,滿足條件的才給容器注冊Bean,本文主要介紹了SpringBoot中的@Conditional?注解的使用
    2024-01-01
  • Mybatis詳細對比一級緩存與二級緩存

    Mybatis詳細對比一級緩存與二級緩存

    MyBatis 包含一個非常強大的查詢緩存特性,它可以非常方便地配置和定制,緩存可以極大的提升查詢效率。MyBatis中默認(rèn)定義了兩級緩存,分別是一級緩存和二級緩存
    2022-10-10
  • Java使用數(shù)組實現(xiàn)ArrayList的動態(tài)擴容的方法

    Java使用數(shù)組實現(xiàn)ArrayList的動態(tài)擴容的方法

    這篇文章主要介紹了Java使用數(shù)組實現(xiàn)ArrayList的動態(tài)擴容的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Java單例模式利用HashMap實現(xiàn)緩存數(shù)據(jù)

    Java單例模式利用HashMap實現(xiàn)緩存數(shù)據(jù)

    這篇文章主要為大家詳細介紹了Java單例模式利用HashMap實現(xiàn)緩存數(shù)據(jù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Java基礎(chǔ)詳解之集合框架工具Collections

    Java基礎(chǔ)詳解之集合框架工具Collections

    這篇文章主要介紹了Java基礎(chǔ)詳解之集合框架工具Collections,文中有非常詳細的代碼示例,對正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-04-04
  • JAVA中Context的詳細介紹和實例分析

    JAVA中Context的詳細介紹和實例分析

    這篇文章主要介紹了JAVA中Context的詳細介紹和實例分析,Context是維持android各組件能夠正常工作的一個核心功能類。如果感興趣來學(xué)習(xí)一下
    2020-07-07
  • Spring Security permitAll()不允許匿名訪問的操作

    Spring Security permitAll()不允許匿名訪問的操作

    這篇文章主要介紹了Spring Security permitAll()不允許匿名訪問的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringBoot實現(xiàn)文件上傳下載實時進度條功能(附源碼)

    SpringBoot實現(xiàn)文件上傳下載實時進度條功能(附源碼)

    這篇文章主要為大家詳細介紹了SpringBoot如何實現(xiàn)文件上傳下載實時進度條功能,文中的示例代碼講解詳細,感興趣的小伙伴可以學(xué)習(xí)一下
    2022-10-10
  • JDBC 實現(xiàn)通用的增刪改查基礎(chǔ)類方法

    JDBC 實現(xiàn)通用的增刪改查基礎(chǔ)類方法

    下面小編就為大家分享一篇JDBC 實現(xiàn)通用的增刪改查基礎(chǔ)類方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01

最新評論