91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

    梅州市| 渑池县| 新昌县| 温州市| 勐海县| 湘西| 莆田市| 治县。| 黔东| 庄浪县| 东城区| 承德县| 石景山区| 高邮市| 博客| 沙田区| 江北区| 三台县| 宁波市| 开原市| 津南区| 平原县| 永年县| 自治县| 鹤壁市| 乌恰县| 城步| 孙吴县| 富顺县| 宁阳县| 锦州市| 雅江县| 南木林县| 卢湾区| 泗洪县| 昭通市| 邻水| 瑞昌市| 乐山市| 鹤山市| 德令哈市|