MyBatis中动态sql的模糊搜索、foreach实现In集合的用法
生活随笔
收集整理的這篇文章主要介紹了
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)題。
- 上一篇: MyBatis中提示:invalid c
- 下一篇: MyBatis中动态sql实现传递多个参