mybatis 根據id批量刪除的兩種方法


原文:https://blog.csdn.net/qq_40010745/article/details/81032218

mybatis 根據id批量刪除的兩種方法

第一種,直接傳遞給mapper.xml  集合/數組形式

  1. < delete id="deleteByLogic" parameterType = "java.util.List">
  2. delete from user where 1>2
  3.      or id in
  4. < foreach collection="list" item="item" open="(" separator="," close=")" >
  5.      #{item}
  6. < /foreach>
  7. </delete>
 

1.     如果傳入的是單參數且參數類型是一個List的時候,collection屬性值為list

int deleteByLogic(List list);

2.     如果傳入的是單參數且參數類型是一個array數組的時候, 參數類型為parameterType="int"     集合    collection的屬性值為array 

int deleteByLogic(int[] array);
 
  1. <foreach item="item" collection="array" open="(" separator="," close=")">
  2. #{item}
  3. </foreach>

第二種,直接在service中將數據給分裝傳遞到mapper中
    前端封裝為以,為分隔符的id字符串。調用下方工具類。生成數據類型為(‘12’,‘34’....)形式

  1. /**
  2. * StringUtil.getSqlInStrByStrArray() <BR>
  3. * <P>Author : wyp </P>
  4. * <P>Date : 2016年6月15日下午6:14:05</P>
  5. * <P>Desc : 數組字符串轉換為SQL in 字符串拼接 </P>
  6. * @param strArray 數組字符串
  7. * @return SQL in 字符串
  8. */
  9. public static String getSqlInStrByStrArray(String str) {
  10. StringBuffer temp = new StringBuffer();
  11. if(StringUtils.isEmpty(str)){
  12. return "('')";
  13. }
  14. temp.append("(");
  15. if(StringUtils.isNotEmpty(str)){
  16. String[] strArray=str.split(",");
  17. if (strArray != null && strArray.length > 0 ) {
  18. for (int i = 0; i < strArray.length; i++) {
  19. temp.append("'");
  20. temp.append(strArray[i]);
  21. temp.append("'");
  22. if (i != (strArray.length-1) ) {
  23. temp.append(",");
  24. }
  25. }
  26. }
  27. }
  28. temp.append(")");
  29. return temp.toString();
  30. }
  31.  

   在mapper中直接使用 $ 符號接收即可

int deleteByLogic(String ids);

 

  1. <delete id="deleteByLogic" parameterType = "java.util.List">
  2. delete from user where 1>2
  3. or id in ${ids}
  4. </delete>

還有第三種。不過比較浪費資源

        直接在service中循環調用mapper中的delete方法。.....


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM