首页 > 数据库 > MySQL > 正文

mybatis mysql delete in操作只能删除第一条数据的方法

2024-07-24 12:49:50
字体:
来源:转载
供稿:网友

出现的Bug

如图,我开始复制delete语句和参数到数据库执行,删除两条数据,但是后台执行确只删除一条数据,当时表示一脸懵逼

 分析原因

分析原因

如图,正确的参数传值应该是这样的,聪明的同学,应该就知道哪里错了

解决问题

 解决问题

我就不贴开始的代码了,直接贴解决bug的代码

mybatis中的代码

<!-- 批量删除--> <delete id="deleteByIds" parameterType="int[]"> <![CDATA[ DELETE FROM p_customer WHERE customerId in ]]> <foreach collection="array" item="arr" index="no" open="(" separator="," close=")"> #{arr} </foreach> </delete>

controller中的代码

/** * 删除和批量删除 */ @RequestMapping(value = "/del", method = RequestMethod.POST, produces = { MediaType.APPLICATION_JSON_VALUE }) public ResponseEntity<PCustomerVo> delete(@RequestParam String customerId) throws Exception { //获取批量删除的id,去掉最后一个“,” customerId=customerId.substring(0,customerId.length()-1); String[] strarr=customerId.split(","); int[] arr=new int[strarr.length]; for(int i=0;i<strarr.length;i++){ arr[i]=Integer.parseInt(strarr[i]); } pcustomerService.deletes(arr); return new ResponseEntity<>(HttpStatus.OK); }

总结

以上所述是小编给大家介绍的mybatis mysql delete in操作只能删除第一条数据,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对错新站长站网站的支持!

您可能感兴趣的文章:

MyBatis直接执行SQL的工具SqlMapper如何批量测试Mybatis项目中的Sql是否正确详解Mybatis核心组成部分之SQL映射文件揭秘详解Mybatis学习笔记之动态SQL揭秘MyBatis中动态sql的实现方法示例mybatis连接MySQL8出现的问题解决方法详解Mybatis逆向工程中使用Mysql8.0版本驱动遇到的问题详解mybatis.generator配上最新的mysql 8.0.11的一些坑SQL 正则表达式及mybatis中使用正则表达式MyBatis执行动态SQL的方法
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表