中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis中關于in的使用方法有哪些

發布時間:2023-02-27 10:40:54 來源:億速云 閱讀:133 作者:iii 欄目:開發技術

本篇內容主要講解“mybatis中關于in的使用方法有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“mybatis中關于in的使用方法有哪些”吧!

    mybatis in的使用方法

    很多人都想著拼接字符串用比如in(‘1’,‘2’)這樣的方式去獲取數據,其實沒有這個必要,mybatis有foreach方法來自動用這樣的數據

    如下:

    比如傳入的是roleIdList

    //上面省略
    xxxxx
    WHERE ROLE_ID in
            <foreach collection="list" item="item" index="index" open="(" separator="," close=")">
                #{item}
            </foreach>

    mybatis使用in做范圍查詢的坑

    錯誤展示

    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>

    為啥能這樣改?

    當參數采用:#{} : 解析為一個 JDBC 預編譯語句(prepared statement)的參數標記符,一個 #{ } 被解析為一個參數占位符 。${}: 僅僅為一個純碎的 string 替換,在動態 SQL 解析階段將會進行變量替換。

    這種改法看似簡單,但是會有安全隱患,容易遭黑客跨腳本攻擊。

    所以推薦第二種改法。

    改法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>

    這里還是使用#{},這樣就不會遭受跨腳本的攻擊了。

    到此,相信大家對“mybatis中關于in的使用方法有哪些”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    高陵县| 龙海市| 合江县| 林甸县| 鹤峰县| 施甸县| 定西市| 偏关县| 祁东县| 孙吴县| 丰台区| 固原市| 昆明市| 山东省| 克山县| 雅安市| 延寿县| 钟山县| 收藏| 从化市| 南宫市| 应城市| 金川县| 沁水县| 庐江县| 兰考县| 贵南县| 萨嘎县| 山阳县| 贞丰县| 浦北县| 新乡市| 漳浦县| 唐海县| 尖扎县| 万州区| 鄂州市| 法库县| 高陵县| 宜黄县| 灵武市|