Druid + Mybatis批量增删写法

当使用Druid连接池进行数据库操作时,如果开启SQL注入防火墙,可能会遇到批量处理的限制。针对这个问题,文章介绍了如何在Mybatis中进行正确的批量删除和插入操作。在批量删除时,避免循环删除,改用Mybatis的批量删除语法;在插入操作中,展示了批量插入的示例,以确保高效且符合Druid的安全规范。
摘要由CSDN通过智能技术生成
org.springframework.jdbc.UncategorizedSQLException: 
### Error updating database.  Cause: java.sql.SQLException: sql injection violation, syntax error: syntax error, error in :……

数据库操作报上面的错误,是由于Druid连接池开启了SQL注入防火墙。

原来批量删除记录是按主键,做循环删除,原以为这样偷懒就搞定了,结果被Druid挡住。老老实实的写批量删除吧,用的是Mybatis:

  <delete id="deleteBatch" parameterType="java.lang.String">
    delete from table1
    where id IN (
    <foreach collection="list" item="item" separator=",">
       #{item.stuId,jdbcType=VARCHAR}
    </foreach>
    )    
  </delete>

mapper类中这么写:

int deleteBatch(@Param("list") List<Student> list);

另外,插入操作也存在类似问题,需要批量处理,示例:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值