当前位置: 首页 > news >正文

浅谈mysql 的批量delete 和 使用in条件批量删除问题

在考虑这两个DELETE语句的性能时,我们需要考虑数据库如何执行这些查询以及它们背后可能涉及的索引和数据结构。

    1.执行多个单独的DELETE语句:

   

DELETE FROM a WHERE b = 1 AND c = 1;  
...  DELETE FROM a WHERE b = 1000 AND c = 1000;

这种方法的优点是每个DELETE语句都很简单,且如果a表上有针对b和c的复合索引,数据库优化器可以高效地执行每个DELETE操作。此外,如果每次DELETE影响的记录数较少,这种分批处理的方式可以减少锁定的资源数量,降低对其他查询的影响。

然而,这种方法的缺点是存在大量的网络往返(如果客户端和数据库服务器分开部署),以及可能的日志记录开销(取决于数据库的配置和隔离级别)。

2.单个DELETE语句使用IN子句:

DELETE FROM a WHERE b IN (1,...,1000) AND c IN (1,...,1000);

 

    这种方法的优点是只需要一个网络往返和一个事务日志记录条目(再次取决于配置和隔离级别)。但是,这种方法的性能取决于多个因素:

  •  数据库优化器如何解析这个复杂的IN子句,并确定最佳的查询计划。
  •  表a上是否有合适的索引来加速查询。
  •  数据库是否能够智能地识别出只有那些b和c值都匹配的记录才应该被删除。

    需要注意的是,这个IN子句可能不会按预期工作,因为它可能会产生笛卡尔积的效果,即它会尝试匹配所有可能的(b, c)组合,而不仅仅是那些实际存在的组合。如果b和c的值范围不匹配(即不是每个b值都对应一个相同的c值),那么这个查询可能会删除错误的记录。

性能建议:

    如果可能的话,使用第一个方法(即多个单独的DELETE语句),特别是当你知道要删除的确切记录时。这通常更加直观,且性能上可能更好(特别是当你有合适的索引时)。
    如果必须使用第二个方法(即单个DELETE语句使用IN子句),请确保你的IN子句正确地描述了要删除的记录集,并且已经为相关的列建立了合适的索引。此外,请确保你的数据库优化器能够智能地处理这个查询。
    在任何情况下,都应该在生产环境中执行任何删除操作之前,先在测试环境中验证其性能和正确性。
    考虑使用事务来包装多个DELETE语句,以确保数据的一致性和可恢复性。如果可能的话,尽量减少事务的大小和持续时间,以减少锁定的资源数量。

http://www.lryc.cn/news/369114.html

相关文章:

  • 【Spring Boot】过滤敏感词的两种实现
  • 在 Zustand 中管理状态能使用类(Class)吗
  • MoreTable 方法selectWithFun,count 使用实例
  • 【SpringBoot】在Spring中使用自定义条件类在Java声明Bean时实现条件注入
  • 网卡聚合链路配置
  • PlantSimulation导入cad图作为背景
  • 【大模型】个人对大模型选择的见解
  • java的反射和python的鸭子类型
  • 爬虫工具yt-dlp
  • 【代码随想录训练营】【Day 50】【动态规划-9】| Leetcode 198, 213, 337
  • 源码讲解kafka 如何使用零拷贝技术(zero-copy)
  • Ubuntu20.04配置qwen0.5B记录
  • java自学阶段二:JavaWeb开发--day80(项目实战2之苍穹外卖)
  • HPUX系统Oracle RAC如何添加ASM磁盘
  • Jmeter 压力测测试的简单入门
  • N叉树的层序遍历-力扣
  • 解决阿里云的端口添加安全组仍然无法扫描到
  • 【因果推断python】26_双重稳健估计1
  • C语言 图形化界面方式连接MySQL【C/C++】【图形化界面组件分享】
  • Unity DOTS技术(十五) 物理系统
  • Java线程安全
  • Solidity选择使用 require 语句还是条件语句结合手动触发 revert 操作?回滚交易和抛出异常如何选择?
  • SpringCloud 网关配置websocket
  • 基于JavaScript 实现近邻算法以及优化方案
  • 移动端适配和响应式页面中的常用单位
  • 麒麟v10系统arm64架构openssh9.7p1的rpm包
  • 刚刚❗️德勤2025校招暑期实习测评笔试SHL测评题库已发(答案)
  • python对视频进行帧处理以及裁减部分区域
  • Python栈的编程题目
  • ROS云课三分钟外传之CoppeliaSim_Edu_V4_1_0_Ubuntu16_04