日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

MyBatis中动态sql的模糊搜索、foreach实现In集合的用法

發(fā)布時(shí)間:2025/3/19 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MyBatis中动态sql的模糊搜索、foreach实现In集合的用法 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

場(chǎng)景

在使用MyBatis的動(dòng)態(tài)sql時(shí),常見(jiàn)的是傳遞一個(gè)ID的數(shù)組,查詢(xún)記錄的

ID在這個(gè)數(shù)組中的記錄和模糊搜索這兩種場(chǎng)景。

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
關(guān)注公眾號(hào)
霸道的程序猿
獲取編程相關(guān)電子書(shū)、教程推送與免費(fèi)下載。

實(shí)現(xiàn)

模糊搜索的實(shí)現(xiàn)

mapper接口寫(xiě)法:

public List<KqDksz> selectKqDkszListBySx(String xm);

xml寫(xiě)法:

??? <select id="selectKqDkszListBySx"? resultMap="KqDkszResult"><include refid="selectKqDkszVoJoinJibenXinXi"/><where><if test="xm != null? and xm != ''"> and j.xm like concat('%', #{xm}, '%')</if></where></select>

foreach實(shí)現(xiàn)in集合

mapper層接口寫(xiě)法:

public int deleteKqBcglXiangxiByIds(Long[] ids);

xml寫(xiě)法:

??? <delete id="deleteKqBcglXiangxiByIds" parameterType="String">delete from kq_bcgl_xiangxi where ID in<foreach item="id" collection="array" open="(" separator="," close=")">#{id}</foreach></delete>

注意:

這里的參數(shù)為數(shù)組參數(shù),就需要把collection屬性設(shè)置為array

但是這是數(shù)組默認(rèn)的名字,推薦使用@Param來(lái)指定參數(shù)的名字,這時(shí)collection就設(shè)置為通過(guò)@Param注解指定的名字。

比如:

?public List<KqKqrysz> selectKqKqryszListBySx(@Param("badao")Long[] bmids);

對(duì)應(yīng)的是

???????????? <foreach collection="badao" item="item" open="(" separator="," close=")">${item}</foreach>

如果這里不是數(shù)組而是list的話(huà),那么其collection默認(rèn)的就是list而不是array了。

總結(jié)

以上是生活随笔為你收集整理的MyBatis中动态sql的模糊搜索、foreach实现In集合的用法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。