mybatis传入list、array等数据集合的处理

先上代码
//在dao类里面
int deleteBatchQuestion(@Param(value = "questionID") List<Integer> questionID); 
//在xml里面
<delete id="deleteBatchQuestion" parameterType="java.util.List">
    DELETE from single_question where
        Single_QuestionID
        <foreach collection="questionID" item="Single_QuestionID"
                index="index" open="in(" close=")" separator=",">
                #{questionID[${index}]}
            </foreach>
    </delete>

 

这里用到了mybatis的foreach元素,该元素下有 collection、item、index、open、close、separator六个属性。其中collection中要写方法声明里@Param中注解的名字(网上很多版本都说可以直接用list表示同时去掉注解,但我没有成功)。其他六种属性看名字就很好理解了。整条语句会在拼接成 DELETE from single_question where Single_QuestionID IN
(1,2,3...) 类似与这样的语句。其实在Spring接管mybatis之后,每一条sql命令执行前都会对sql进行拼接,然后再去执行。可以使用IDEA自带的反编译工具就可以直接调整sql执行的整个过程(可能过程比较无聊,但谁让咱做程序员来,多看源码还是很有帮助滴。。。。)


这里再说一下和不一样的地方就是
#{questionID[${index}]}
这个地方要写成这样,网上很多人这么写 {questionID} 可惜在我这里经常报错。。。。。

 

转载于:https://www.cnblogs.com/luckyQi/p/7745031.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值