【MySQL基础-16】MySQL DELETE语句:深入理解与应用实践
1. DELETE语句基础:数据删除的艺术
在数据库管理中,DELETE语句是维护数据完整性和清理过期信息的关键工具。与日常生活中的"删除"不同,数据库中的删除操作需要更加谨慎和精确,因为数据一旦删除,恢复可能非常困难(除非有备份)。
MySQL的DELETE语句允许我们从一个或多个表中删除记录,其基本语法简单直观:
DELETE FROM table_name
[WHERE condition]
[ORDER BY ...]
[LIMIT row_count];
著名数据库专家C.J. Date曾说过:"数据的价值不在于它的存在,而在于它的准确性。"DELETE语句正是帮助我们维护这种准确性的重要手段。
2. DELETE语句的工作原理
2.1 执行流程解析
- 解析阶段:MySQL解析SQL语句,确定操作的表和条件
- 计划阶段:优化器确定执行计划,可能使用索引加速查找
- 锁定阶段:获取必要的行锁或表锁(取决于存储引擎)
- 删除阶段:标记匹配的行为"已删除"
- 提交阶段:事务提交后,空间可能被回收(InnoDB)
2.2 不同存储引擎的删除机制
| 存储引擎 | 删除机制 | 空间回收 | 事务支持 |
|---|---|---|---|
| InnoDB | 标记删除,实际数据在undo log中 | 不会立即回收,可通过OPTIMIZE TABLE回收 | 支持 |
| MyISAM | 立即删除,空间放入空闲列表 | 新插入可重用空间 | 不支持 |
| MEMORY | 立即释放内存 | 立即回收 | 不支持 |
2.3 删除操作的日志记录
InnoDB引擎在执行DELETE时:
- 记录undo log用于事务回滚
- 记录redo log用于崩溃恢复
- 如果是主从复制环境,还会记录binlog
3. DELETE的进阶用法
3.1 条件删除:精准定位数据
-- 删除特定条件的记录
DELETE FROM employees
WHERE department = 'HR' AND hire_date < '2020-01-01';-- 使用子查询确定删除范围
DELETE FROM orders
WHERE customer_id IN (SELECT customer_id FROM customers WHERE status = 'inactive');
3.2 多表删除:关联数据清理
-- 删除多表关联数据(方法1)
DELETE t1, t2
FROM table1 t1
JOIN table2 t2 ON t1.id = t2.table1_id
WHERE t1.status = 'expired';-- 删除多表关联数据(方法2)
DELETE FROM t1, t2
USING table1 t1
JOIN table2 t2 ON t1.id = t2.table1_id
WHERE t1.status = 'expired';
3.3 排序和限量删除
-- 删除最老的10条日志记录
DELETE FROM system_logs
ORDER BY create_time ASC
LIMIT 10;
3.4 批量删除与性能优化
对于大型表,一次性删除大量数据可能导致性能问题,可以采用分批次删除:
-- 分批删除(每次1000条)
DELETE FROM large_table
WHERE condition = true
LIMIT 1000;
4. DELETE与相关操作的比较
4.1 DELETE vs TRUNCATE
| 特性 | DELETE | TRUNCATE |
|---|---|---|
| 语法 | DML语句 | DDL语句 |
| 性能 | 较慢(逐行删除) | 极快(直接删除表数据文件) |
| 可回滚 | 支持(事务内) | 不支持 |
| 触发器 | 会触发 | 不会触发 |
| 自增ID | 不重置 | 重置 |
4.2 DELETE vs DROP
DROP TABLE是完全删除表结构和数据,而DELETE只是删除表中的数据。
5. DELETE操作的安全实践
5.1 删除前的必备检查清单
-
备份数据:执行重要删除前先备份
CREATE TABLE employees_backup AS SELECT * FROM employees; -
使用事务:确保可以回滚
START TRANSACTION; DELETE FROM temp_data; -- 检查结果后再决定提交或回滚 ROLLBACK; -- 或 COMMIT; -
先SELECT后DELETE:验证删除范围
SELECT * FROM orders WHERE status = 'cancelled'; -- 先检查 DELETE FROM orders WHERE status = 'cancelled'; -- 再删除
5.2 防止误删的安全措施
-
设置SQL_SAFE_UPDATES:
SET SQL_SAFE_UPDATES = 1; -- 要求DELETE必须有WHERE条件 -
权限控制:限制开发环境的DELETE权限
-
使用软删除模式:
UPDATE products SET is_deleted = 1 WHERE product_id = 123; -- 而非 DELETE FROM products WHERE product_id = 123;
6. DELETE性能优化策略
6.1 索引利用
确保WHERE条件中的列有适当索引:
-- 假设在status列上有索引
DELETE FROM orders WHERE status = 'expired';
6.2 大批量删除优化
对于超大表删除:
-
分批删除(如前所述)
-
创建新表保留需要的数据,然后重命名
CREATE TABLE new_orders AS SELECT * FROM orders WHERE status != 'expired'; RENAME TABLE orders TO old_orders, new_orders TO orders; DROP TABLE old_orders; -
使用分区表,直接删除整个分区
ALTER TABLE sales DROP PARTITION p2020;
6.3 锁优化
- 在低峰期执行大规模删除
- 考虑使用
LOCK IN SHARE MODE或FOR UPDATE控制锁粒度 - 对于InnoDB,调整事务隔离级别可能有助于减少锁冲突
7. 特殊场景处理
7.1 自增ID处理
删除后自增ID不会重置,如需连续ID:
-- 方法1:重建表
ALTER TABLE table_name AUTO_INCREMENT = 1;-- 方法2:使用TRUNCATE(会重置自增ID)
TRUNCATE TABLE table_name;
2. 外键约束下的删除
-
级联删除:
CREATE TABLE orders (id INT PRIMARY KEY,customer_id INT,FOREIGN KEY (customer_id) REFERENCES customers(id) ON DELETE CASCADE ); -
先删除子表记录:
-- 先删除订单明细 DELETE FROM order_items WHERE order_id = 123; -- 再删除订单 DELETE FROM orders WHERE order_id = 123;
8. DELETE监控与审计
8.1 监控删除操作
-- 开启通用查询日志
SET GLOBAL general_log = 'ON';-- 或使用审计插件(如MySQL Enterprise Audit)
8.2 实现删除审计
创建审计表记录删除操作:
CREATE TABLE delete_audit (id INT AUTO_INCREMENT PRIMARY KEY,table_name VARCHAR(100),deleted_id INT,deleted_at DATETIME,deleted_by VARCHAR(100)
);-- 使用触发器记录删除
DELIMITER //
CREATE TRIGGER audit_employee_delete
AFTER DELETE ON employees
FOR EACH ROW
BEGININSERT INTO delete_audit (table_name, deleted_id, deleted_at, deleted_by)VALUES ('employees', OLD.employee_id, NOW(), CURRENT_USER());
END //
DELIMITER ;
9. 总结与最佳实践
MySQL的DELETE语句是数据管理中的强大工具,但正如能力越大责任越大,不当的删除操作可能导致灾难性后果。以下是关键实践建议:
- 永远先备份:重要数据删除前必须备份
- 使用事务:特别是在生产环境中
- 精确限定条件:避免无WHERE条件的全表删除
- 考虑性能影响:大批量删除采用分批策略
- 实施审计:记录关键数据的删除操作
- 优先软删除:重要业务数据考虑使用标记删除而非物理删除
记住数据库大师Michael Stonebraker的忠告:"数据比代码更持久。"谨慎对待每一个DELETE操作,确保你的数据管理既高效又安全。
相关文章:
【MySQL基础-16】MySQL DELETE语句:深入理解与应用实践
1. DELETE语句基础:数据删除的艺术 在数据库管理中,DELETE语句是维护数据完整性和清理过期信息的关键工具。与日常生活中的"删除"不同,数据库中的删除操作需要更加谨慎和精确,因为数据一旦删除,恢复可能非常…...
相对位置嵌入和旋转位置编码
1. 相对位置嵌入:给注意力机制加“人际关系记忆” 像班级座位表 想象全班同学(序列的各个元素)坐成一个圈,老师(模型)要记住每个人之间的相对位置: 传统方法:老师给每个座位贴绝对…...
Unity编辑器功能及拓展(1) —特殊的Editor文件夹
Unity中的Editor文件夹是一个具有特殊用途的目录,主要用于存放与编辑器扩展功能相关的脚本和资源。 一.纠缠不清的UnityEditor 我们Unity中进行游戏构建时,我们经常遇到关于UnityEditor相关命名空间丢失的报错,这时候,只得将报错…...
REC一些操作解法
一.Linux命令长度突破 1.源码如下 <?php $param $_REQUEST[param];if ( strlen($param) < 8 ) {echo shell_exec($param); } 2.源码分析 echo执行函数,$_REQUEST可以接post、get、cookie传参 3.破题思路 源码中对参数长度做了限制,小于8位&a…...
powershell7.5.0不支持conda的问题
经历:这周手欠使用vscode的powershell时提示我更新,我就更新了,更新完激活不了conda环境了,查询了半天是powershell最新版7.5.0与目前conda25.1.1以前的版本不支持的问题。 问题环境:powershell版本>7.5.0ÿ…...
Android Jetpack学习总结(源码级理解)
ViewModel 和 LiveData 是 Android Jetpack 组件库中的两个核心组件,它们能帮助开发者更有效地管理 UI 相关的数据,并且能够在配置变更(如屏幕旋转)时保存和恢复 UI 数据。 ViewModel作用 瞬态数据丢失的恢复,比如横竖…...
Unity中UDP异步通信常用API使用
Begin开头的方法 BeginSendTo BeginSendTo 是 UdpClient 类中的一个重要方法,用于开始一个异步操作来发送 UDP 数据报到指定的远程端点 public IAsyncResult BeginSendTo(byte[] datagram,int bytes,IPEndPoint endPoint,AsyncCallback requestCallback,object s…...
解决Dify:failed to init dify plugin db问题
Dify最新版本1.1.3(langgenius/dify: Dify is an open-source LLM app development platform. Difys intuitive interface combines AI workflow, RAG pipeline, agent capabilities, model management, observability features and more, letting you quickly go from prototy…...
[AI绘图] ComfyUI 中自定义节点插件安装方法
ComfyUI 是一个强大的 AI 图像生成工具,支持自定义节点插件扩展其功能。本文介绍 ComfyUI 中安装自定义节点插件的三种方法,包括 Git Clone 方式、插件管理器安装方式,以及手动解压 ZIP 文件的方法,并分析它们的优缺点。 1. Git Clone 方法 使用 git clone 是最稳定且推荐…...
【机械视觉】C#+VisionPro联合编程———【六、visionPro连接工业相机设备】
【机械视觉】C#VisionPro联合编程———【六、visionPro连接工业相机设备】 目录 【机械视觉】C#VisionPro联合编程———【六、visionPro连接工业相机设备】 前言: 连接步骤说明 一. 硬件连接 支持的相机接口类型: 连接步骤 2. 软件配置 Visio…...
CI/CD基础知识
什么是CI/CD CI:持续集成,开发人员频繁地将代码集成到主干(主分支)中每次集成都通过自动化构建和测试来验证,从而尽早发现集成错误,常用的CI工具包括Jenkins、Travis CI、CircleCI、GitLab CI等 CD&#…...
蓝桥杯 之 图论基础+并查集
文章目录 习题联盟X蓝桥幼儿园 图论基础 并查集 并查集,总的来说,操作分为三步初始化(每一个节点的父亲是自己),定义union(index1,index2)函数,定义find(index)函数 并查集详细内容博客 习题 联盟X 联盟X 典型的求解连通分支…...
C# .net ai Agent AI视觉应用 写代码 改作业 识别屏幕 标注等
C# net deepseek RAG AI开发 全流程 介绍_c# 向量处理 deepseek-CSDN博客 视觉多模态大模型 通义千问2.5-VL-72B AI大模型能看懂图 看懂了后能干啥呢 如看懂图 让Agent 写代码 ,改作业,识别屏幕 标注等等。。。 据说是目前最好的免费图片识别框架 通…...
不使用自动映射驼峰命名法,直接在接口上使用注解@Results方法映射
3. 使用注解方式配置 在接口方法上使用 Results 注解: java 复制 Select("SELECT user_name, create_time FROM user WHERE id #{id}") Results({Result(column "user_name", property "userName"),Result(column "crea…...
15届蓝桥JavaB组 前6道题解
15届蓝桥JavaB组 前6道题解 报数游戏类斐波那契循环数分布式队列食堂最优分组星际旅行 报数游戏 import java.util.Scanner;//分析: //20和24的最小公倍数是120 //题目给出了前10个数,发现第10个数是120,说明每10个数出现一个公倍数 //第20个…...
蓝桥杯 14 天 十五届蓝桥杯 数字诗意
static boolean kkk(long x) {if(x1)return true;else {// 初始化xx为1,用于计算2的幂long xx 1;// 循环60次,检查2的幂是否等于xfor (int i 1; i < 60; i) {xx * 2; // 每次将xx乘以2if (xx x) { // 如果xx等于x,说明x是2的幂…...
MP4音视频格式
1.MP4 MP4是一种用于封装音视频/字幕/图片/章节信息等数据的多媒体容器格式,是MPEG-4系列的成员之一 2.文件结构 MP4由一层层的嵌套Box(atom)组成 [ size (4 bytes) ][ type (4 bytes)][ payload (嵌套box或者数据) ] 3.常见Box 类型名称…...
国内GitHub镜像源全解析:加速访问与替代方案指南
在数字化开发日益普及的今天,GitHub作为全球最大的代码托管平台,已成为开发者不可或缺的资源库。然而,由于网络环境的限制,国内用户在访问GitHub时常常面临速度慢、连接不稳定等问题。为了提升开发效率,国内涌现出多个GitHub镜像源,为开发者提供了快速、稳定的代码克隆与…...
CentOS 7 挂载与卸载文件系统笔记
挂载文件系统 挂载的基本概念 挂载是将存储设备(如硬盘分区、U 盘、光盘等)连接到 Linux 文件系统的特定目录(挂载点),使得系统能够访问存储设备上的数据。 查看已挂载的文件系统 命令:mount 或 df -h mo…...
责任链模式-java
1、spring依赖注入模式 @Configuration public class ChainConfig {@Beanpublic ChainSpringFactory chainSpringFactory(List<IHandler<DemoOne,Boolean>> handlerList){return new ChainSpringFactory(handlerList);}} public class DemoOne { }public abstract…...
Vue3动态加载组件,警告:Vue received a Component than was made a reactive object
场景 2个按钮,点击之后,下面加载不同的组件。 现象 分析 实际动态加载的组件,不是深层响应式的,推荐使用 shallowReactive 或 shallowRef,即浅层作用形式,仅最外层是响应式,以此来提升性能。…...
【源码阅读/Vue Flask前后端】简历数据查询功能
目录 一、Flask后端部分modelServiceroute 二、Vue前端部分index.js main.vue功能界面templatescriptstyle 一般就是三个层面,model层面用来建立数据库的字段,service用来对model进行操作,写一些数据库操作的代码,route就是具体的…...
Vue背景介绍+声明式渲染+数据响应式
一、Vue背景 1. 为什么学Vue 1.前后端开发就业必备技能 2.岗位多,绝⼤互联⽹公司都在使⽤Vue,还可以助⼒SpringBoot、C等项⽬开发 3.提⾼开发效率 更少的时间,干更多的活,提高项目开发速度 原生JS做法 Vue做法 总而言之: 使用Vue能够赋能、提升就业竞争…...
HarmonyOS NEXT 鸿蒙中手写和使用第三方仓库封装Logger打印工具
应用场景 在鸿蒙开发中,我们在很多时候调试代码都需要用到日志打印工具,但无论是hilog还是console.log,都用起来相对麻烦,而且需要手动将对象转换为JSON字符串的方式才能打印,并且在控制台日志中输出的格式也非常丑。所以下面我们…...
如何使用 CSS 的backdrop - filter属性实现背景模糊等特效,有哪些兼容性问题?
大白话如何使用 CSS 的backdrop - filter属性实现背景模糊等特效,有哪些兼容性问题? 嘿,朋友!今天咱们来聊聊 CSS 里超酷的 backdrop-filter 属性,它能让你轻松实现背景模糊等超炫特效。咱们先看看这属性到底是啥&…...
批量合并 PDF 文档,支持合并成单个文档,也支持按文件夹合并 PDF 文档
在日常工作中,合并多个 PDF 文档为一个文件是非常常见的需求。通过合并 PDF,不仅能够更方便地进行管理,还能在特定场景下(如批量打印)提高效率。那么,当我们需要批量合并多个 PDF 文件时,是否有…...
rbpf虚拟机-汇编和反汇编器
文章目录 一、概述二、主要功能三、关键函数解析3.1 汇编器3.1.1 parse -转换为Instruction列表3.1.2 assemble_internal-转换为Insn 3.2 反汇编器3.2.1 to_insn_vec-转换为机器指令 四、总结 Welcome to Code Blocks blog 本篇文章主要介绍了 [rbpf虚拟机-汇编和反汇编器] ❤…...
虚拟现实--->unity学习
前言:这学期劳动课选了虚拟现实,其中老师算挺认真的,当然对一些不感兴趣的同学来说是一种折磨,我对这个unity的学习以及后续的虚幻引擎刚开始连基础的概念都没有,后面渐渐也是滋生了一些兴趣,用这篇博客记录…...
一文详解QT环境搭建:ubuntu20.4安装配置Qt5
随着软件开发技术的不断进步,跨平台应用程序的需求日益增长,开发者们面临着如何在不同操作系统之间保持代码的一致性和效率的问题。Qt作为一个成熟的跨平台C框架,在这方面提供了卓越的支持,不仅简化了GUI应用程序的创建过程&#…...
Gateway实战(三)、断言-时间、Cookie信息
spring cloud-Gateway实战三、断言 断言一)、时间断言相关1、适用场景2、Demo案例二)、断言- Cookie信息1、用户身份验证与会话管理场景及Demo案例2、A/B测试及Demo案例断言 简单了解: 断言是一种在程序设计中用于检查程序状态或条件的机制,在gateway网关里,断言的作用是…...
