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

其他教程   发布日期:2023年07月12日   浏览次数:428

本篇内容主要讲解“mybatis中关于in的使用方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mybatis中关于in的使用方法有哪些”吧!

    mybatis in的使用方法

    很多人都想着拼接字符串用比如in(‘1’,‘2’)这样的方式去获取数据,其实没有这个必要,mybatis有foreach方法来自动用这样的数据

    如下:

    比如传入的是roleIdList

    1. //上面省略
    2. xxxxx
    3. WHERE ROLE_ID in
    4. <foreach collection="list" item="item" index="index" open="(" separator="," close=")">
    5. #{item}
    6. </foreach>

    mybatis使用in做范围查询的坑

    错误展示

    1. List<WmRecommendpic> selectPicListByMap(@Param("recommendIds")String recommendIds);
    2. <select id="selectPicListByMap" resultType="xx.xx.WmRecommendpic" parameterType="java.util.Map">
    3. SELECT * FROM `WmRecommendpic`
    4. WHERE type_id IN (
    5. SELECT DISTINCT type_id FROM `wm_relationship`
    6. WHERE recommend_id IN (#{recommendIds})
    7. AND is_valid=TRUE)
    8. AND is_valid=TRUE
    9. ORDER BY id ASC
    10. </select>

    由于#是不能识别的 所以有两种改法

    改法1

    1. <select id="selectPicListByMap" resultType="xx.xx.WmRecommendpic" parameterType="java.util.Map">
    2. SELECT * FROM `WmRecommendpic`
    3. WHERE type_id IN (
    4. SELECT DISTINCT type_id FROM `wm_relationship`
    5. WHERE recommend_id IN (${recommendIds})
    6. AND is_valid=TRUE)
    7. AND is_valid=TRUE
    8. ORDER BY id ASC
    9. </select>

    为啥能这样改?

    当参数采用:#{} : 解析为一个 JDBC 预编译语句(prepared statement)的参数标记符,一个 #{ } 被解析为一个参数占位符 。${}: 仅仅为一个纯碎的 string 替换,在动态 SQL 解析阶段将会进行变量替换。

    这种改法看似简单,但是会有安全隐患,容易遭黑客跨脚本攻击。

    所以推荐第二种改法。

    改法2

    1. List<WmRecommendpic> selectPicListByMap(Map<String,Object> map);
    1. Map<String,Object> map = new HashMap<>();
    2. map.put("recommendIds", recommendId.split(","));
    3. return this.dao.selectPicListByMap(map);
    1. <select id="selectPicListByMap" resultType="cn.smarthse.modules.platform.entity.apps.WmRecommendpic" parameterType="java.util.Map">
    2. SELECT * FROM `wm_recommendpic`
    3. WHERE type_id IN (
    4. SELECT DISTINCT type_id FROM `wm_relationship`
    5. WHERE recommend_id IN
    6. <foreach item="recommendId" index="index" collection="recommendIds" open="(" separator="," close=")">
    7. #{recommendId}
    8. </foreach>
    9. AND is_valid=TRUE)
    10. AND is_valid=TRUE
    11. ORDER BY id ASC
    12. </select>

    这里还是使用#{},这样就不会遭受跨脚本的攻击了。

    以上就是mybatis中关于in的使用方法有哪些的详细内容,更多关于mybatis中关于in的使用方法有哪些的资料请关注九品源码其它相关文章!