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

mybatis注解開發(fā)使用foreach方式

 更新時間:2024年08月20日 09:07:09   作者:尋夢太極  
這篇文章主要介紹了mybatis注解開發(fā)使用foreach方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

mybatis注解開發(fā)使用foreach

寫法看代碼

    @Select( " <script>" +
            " select id, user_id userId, batch_number batchNumber, unit_name unitName, word_detail wordDetail,word, score, create_time createTime " +
            " from word_practice_records where user_id =#{userId} and batch_number=#{batchNumber} and unit_name=#{unitName} and  word  in "+
            " <foreach collection='wordScoreViewList' open='(' item='wordScore' separator=',' close=')'> #{wordScore.word}</foreach> "+
            " </script>" )
    List<WordPracticeRecords> getLessThan40WordByWordList(@Param("userId") String userId, @Param( "batchNumber" )String batchNumber,
                                                          @Param( "unitName" ) String unitName, @Param( "wordScoreViewList" ) List<WordScoreView>  wordScoreViewList);

注意:

需要再前后增加<script></script> 標(biāo)簽

循環(huán)使用

<foreach collection='wordScoreViewList' open='(' item='wordScore' separator=',' close=')'> 
    #{wordScore.word}
</foreach>

mybatis中的foreach語句簡介

mybatis中的foreach語句適用于多種業(yè)務(wù)場景,主要起的作用是迭代集合。

在實際應(yīng)用場景中,使用一個正確的foreach能夠提高執(zhí)行效率,所以通過記錄最近一次使用foreach的具體場景來了解foreach的具體實現(xiàn)。

Mybatis的foreach語法

通過業(yè)務(wù)層傳入一個LIst集合,其中存放了一批id號,List list 隨后我要對此集合中的id取出依次遍歷,即寫法如下

select * from user where 1=1
<if test="id != null">
    and id in
    <foreach item="item" index="index" collection="list"  open="(" separator="," close=")">
   		'#{item}'
	</foreach>
</if>

等同于以下的mysql寫法:

select * from user where id in (1,2,3,4,5)

其中需要注意的是collection參數(shù)后面的值要與變量名保持一致,我這里為list則需要保持一致,關(guān)于這幾個參數(shù)的詳解在文末會有介紹。

進階寫法

假如我傳過來的是一個以,為分隔符的連貫字符串,例如某個對象中有一個屬性String extInfo = “1,2,3,4,5”,依然跟上述的業(yè)務(wù)場景一致,那我們就需要先將該字符串做處理之后再進行foreach迭代

select * from user where 1=1
<if test="extInfo != null">
    and id in
    <foreach item="item" index="index" collection="extInfo.split(',')"  open="(" separator="," close=")">
   		'#{item}'
	</foreach>
</if>

還有一種業(yè)務(wù)場景是針對Map的迭代,例如有一個key-value對應(yīng)的是ids-List,我們也能通過foreach迭代該map下的ids鍵來實現(xiàn)

select * from user where 1=1
<if test="extInfo != null">
    and id in
    <foreach item="item" index="index" collection="ids"  open="(" separator="," close=")">
   		'#{item}'
	</foreach>
</if>

原理

上述的foreach應(yīng)用場景主要解決了使用in語句迭代批量查詢,迭代刪除以及迭代編輯等批量操作,那其中的參數(shù)具體是什么意思呢。

  • item表示集合中每一個元素進行迭代時的別名
  • index表示索引
  • collection表示要迭代的集合
  • open表示前綴的拼接內(nèi)容
  • separator表示迭代集合
  • close表示后綴的拼接內(nèi)容

基本語法就包括了上述的6個參數(shù),各個參數(shù)都代表著各自的含義,在實際應(yīng)用中使用foreach迭代能夠幫助我們完成各類批量操作。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在IntelliJ IDEA中使用gulp的方法步驟(圖文)

    在IntelliJ IDEA中使用gulp的方法步驟(圖文)

    這篇文章主要介紹了在IntelliJ IDEA中使用gulp的方法步驟(圖文),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • SpringBoot中定制異常頁面的實現(xiàn)方法

    SpringBoot中定制異常頁面的實現(xiàn)方法

    這篇文章主要介紹了SpringBoot中定制異常頁面的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • Java的Flowable工作流之加簽轉(zhuǎn)簽詳解

    Java的Flowable工作流之加簽轉(zhuǎn)簽詳解

    這篇文章主要介紹了Java的Flowable工作流之加簽轉(zhuǎn)簽詳解,Flowable是一個開源的工作流引擎,它提供了一套強大的工具和功能,用于設(shè)計、執(zhí)行和管理各種類型的工作流程,需要的朋友可以參考下
    2023-11-11
  • Java?NIO實現(xiàn)聊天室功能

    Java?NIO實現(xiàn)聊天室功能

    這篇文章主要為大家詳細(xì)介紹了Java?NIO實現(xiàn)聊天室功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • java中生成任意之間數(shù)的隨機數(shù)詳解

    java中生成任意之間數(shù)的隨機數(shù)詳解

    這篇文章主要介紹了java中生成任意之間數(shù)的隨機數(shù)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • 基于java HashMap插入重復(fù)Key值問題

    基于java HashMap插入重復(fù)Key值問題

    這篇文章主要介紹了基于java HashMap插入重復(fù)Key值問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • java數(shù)據(jù)庫數(shù)據(jù)分批讀取的實現(xiàn)示例

    java數(shù)據(jù)庫數(shù)據(jù)分批讀取的實現(xiàn)示例

    在處理大量數(shù)據(jù)時,直接從數(shù)據(jù)庫一次性讀取所有數(shù)據(jù)可能會導(dǎo)致內(nèi)存溢出或者性能下降,本文就來介紹一下java數(shù)據(jù)庫數(shù)據(jù)分批讀取的實現(xiàn)示例,感興趣的可以了解一下
    2024-01-01
  • 使用注解進行Spring開發(fā)的全過程

    使用注解進行Spring開發(fā)的全過程

    使用注解(Annotation)是一種在代碼級別進行說明和標(biāo)記的技術(shù),它從JDK 5.0開始引入,并在現(xiàn)代Java開發(fā)中得到了廣泛應(yīng)用,本文將詳細(xì)介紹Spring框架中常用的注解及示例,幫助開發(fā)者快速掌握Spring注解開發(fā)的要點和技巧,需要的朋友可以參考下
    2023-11-11
  • Java集合List相關(guān)面試題整理大全

    Java集合List相關(guān)面試題整理大全

    這篇文章主要給大家介紹了關(guān)于Java集合List相關(guān)面試題整理的相關(guān)資料,下面將提供一些常見的Java集合類面試題及其解答,幫助讀者更好地準(zhǔn)備面試,需要的朋友可以參考下
    2024-01-01
  • idea解決Git分支合并沖突問題

    idea解決Git分支合并沖突問題

    這篇文章主要介紹了idea解決Git分支合并沖突問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08

最新評論