加入收藏 | 设为首页 | 会员中心 | 我要投稿 站长网 (https://www.92zhanzhang.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2022-03-20 13:05:28 所属栏目:MySql教程 来源:互联网
导读:出现的Bug 我开始复制delete语句和参数到数据库执行,删除两条数据,但是后台执行确只删除一条数据,当时表示一脸懵逼 mybatis mysql delete in操作只能删除第一条数据的方法 分析原因 分析原因 正确的参数传值应该是这样的,聪明的同学,应该就知道哪里错
      出现的Bug
 
      我开始复制delete语句和参数到数据库执行,删除两条数据,但是后台执行确只删除一条数据,当时表示一脸懵逼
 
      mybatis mysql delete in操作只能删除第一条数据的方法 分析原因
 
      分析原因
 
       正确的参数传值应该是这样的,聪明的同学,应该就知道哪里错了
 
解决问题
 
mybatis mysql delete in操作只能删除第一条数据的方法 解决问题
 
我就不贴开始的代码了,直接贴解决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操作只能删除第一条数据,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。

(编辑:站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!