溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis mysql delete in操作只能刪除第一條數據的方法

發布時間:2020-08-24 05:42:30 來源:腳本之家 閱讀:370 作者:低調小熊貓 欄目:MySQL數據庫

出現的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操作只能刪除第一條數據,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女