mybatis中關(guān)于in的使用方法及說明
mybatis in的使用方法
很多人都想著拼接字符串用比如in(‘1’,‘2’)這樣的方式去獲取數(shù)據(jù),其實(shí)沒有這個(gè)必要,mybatis有foreach方法來自動(dòng)用這樣的數(shù)據(jù)
如下:
比如傳入的是roleIdList
//上面省略 xxxxx WHERE ROLE_ID in <foreach collection="list" item="item" index="index" open="(" separator="," close=")"> #{item} </foreach>
mybatis使用in做范圍查詢的坑
錯(cuò)誤展示
List<WmRecommendpic> selectPicListByMap(@Param("recommendIds")String recommendIds); <select id="selectPicListByMap" resultType="xx.xx.WmRecommendpic" ? ? parameterType="java.util.Map"> ?? ??? ? ?? ??? ?SELECT * FROM `WmRecommendpic`? ?? ??? ?WHERE type_id IN ( ?? ??? ??? ?SELECT DISTINCT type_id FROM `wm_relationship`? ?? ??? ??? ?WHERE recommend_id IN (#{recommendIds}) ?? ??? ??? ?AND is_valid=TRUE) ?? ??? ?AND is_valid=TRUE ?? ??? ?ORDER BY id ASC </select>
由于#是不能識別的 所以有兩種改法
改法1
<select id="selectPicListByMap" resultType="xx.xx.WmRecommendpic" ? ? parameterType="java.util.Map"> ?? ??? ? ?? ??? ?SELECT * FROM `WmRecommendpic`? ?? ??? ?WHERE type_id IN ( ?? ??? ??? ?SELECT DISTINCT type_id FROM `wm_relationship`? ?? ??? ??? ?WHERE recommend_id IN (${recommendIds}) ?? ??? ??? ?AND is_valid=TRUE) ?? ??? ?AND is_valid=TRUE ?? ??? ?ORDER BY id ASC </select>
為啥能這樣改?
當(dāng)參數(shù)采用:#{} : 解析為一個(gè) JDBC 預(yù)編譯語句(prepared statement)的參數(shù)標(biāo)記符,一個(gè) #{ } 被解析為一個(gè)參數(shù)占位符 。${}: 僅僅為一個(gè)純碎的 string 替換,在動(dòng)態(tài) SQL 解析階段將會(huì)進(jìn)行變量替換。
這種改法看似簡單,但是會(huì)有安全隱患,容易遭黑客跨腳本攻擊。
所以推薦第二種改法。
改法2
List<WmRecommendpic> selectPicListByMap(Map<String,Object> map);
Map<String,Object> map = new HashMap<>(); map.put("recommendIds", recommendId.split(",")); return this.dao.selectPicListByMap(map);
<select id="selectPicListByMap" resultType="cn.smarthse.modules.platform.entity.apps.WmRecommendpic" parameterType="java.util.Map"> SELECT * FROM `wm_recommendpic` WHERE type_id IN ( SELECT DISTINCT type_id FROM `wm_relationship` WHERE recommend_id IN <foreach item="recommendId" index="index" collection="recommendIds" open="(" separator="," close=")"> #{recommendId} </foreach> AND is_valid=TRUE) AND is_valid=TRUE ORDER BY id ASC </select>
這里還是使用#{},這樣就不會(huì)遭受跨腳本的攻擊了。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java性能工具JMeter實(shí)現(xiàn)上傳與下載腳本編寫
性能測試工作中,文件上傳也是經(jīng)常見的性能壓測場景之一,那么 JMeter 文件上傳下載腳本怎么做,本文詳細(xì)的來介紹一下,感興趣的可以了解一下2021-07-07Java中的構(gòu)造方法this、super的用法詳解
這篇文章較詳細(xì)的給大家介紹了Java中的構(gòu)造方法this、super的用法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-07-07Spring Controller接收前端JSON數(shù)據(jù)請求方式
這篇文章主要為大家介紹了Spring Controller接收前端JSON數(shù)據(jù)請求方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07為何HashSet中使用PRESENT而不是null作為value
這篇文章主要介紹了為何HashSet中使用PRESENT而不是null作為value,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10Java Socket設(shè)置timeout的幾種常用方式說明
這篇文章主要介紹了Java Socket設(shè)置timeout的幾種常用方式說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11