生产数据库批量 UPDATE / DELETE 核心要点-不备份=自行提桶跑路

生产数据库批量 UPDATE / DELETE 核心要点-不备份=自行提桶跑路

1. 执行前必做

先 SELECT 预览影响行数

sql 复制代码
-- 把 UPDATE/DELETE 的 WHERE 条件原封不动拿来 SELECT
SELECT COUNT(*) FROM sys_notify_todo
WHERE fd_app_name = 'OA'
  AND fd_create_time < '2026-05-22 22:16:00';

备份目标数据

sql 复制代码
-- 建备份表
CREATE TABLE sys_notify_todo_bak_20260522 AS
SELECT * FROM sys_notify_todo
WHERE fd_app_name = 'OA'
  AND fd_create_time < '2026-05-22 22:16:00';

2. SQL 写法要点

用 CASE WHEN 代替多条 UPDATE

sql 复制代码
-- ❌ 错误:顺序执行互相覆盖(今天的教训)
UPDATE ... SET fd_module_name = '泛微邮件' WHERE ... = '内部邮件';
UPDATE ... SET fd_module_name = '泛微流程审批' WHERE ... != '内部邮件';

-- ✅ 正确:一条搞定
UPDATE sys_notify_todo
SET fd_module_name = CASE
    WHEN fd_module_name = '内部邮件' THEN '泛微邮件'
    ELSE '泛微流程审批'
END
WHERE fd_app_name = 'OA'
  AND fd_create_time < '2026-05-22 22:16:00';

WHERE 条件必须精准,禁止裸奔

sql 复制代码
-- ❌ 危险
UPDATE sys_notify_todo SET fd_module_name = '泛微邮件';

-- ✅ 安全
UPDATE sys_notify_todo SET fd_module_name = '泛微邮件'
WHERE fd_id IN ('id1', 'id2', 'id3');

3. 事务保护

sql 复制代码
BEGIN;

UPDATE sys_notify_todo
SET fd_module_name = '泛微邮件'
WHERE fd_id IN ('id1', 'id2');

-- 先 SELECT 确认结果对不对
SELECT * FROM sys_notify_todo WHERE fd_id IN ('id1', 'id2');

-- 没问题再提交
COMMIT;

-- 有问题立即回滚
ROLLBACK;

4. 执行后验证

sql 复制代码
-- 更新完马上核对数据是否符合预期
SELECT fd_module_name, COUNT(*) AS cnt
FROM sys_notify_todo
WHERE fd_app_name = 'OA'
  AND fd_create_time < '2026-05-22 22:16:00'
GROUP BY fd_module_name;

核心口诀

  1. 备份先行,导出或建备份表
  2. SELECT 预览,确认影响行数
  3. 事务包裹,出错立即 ROLLBACK
  4. CASE WHEN,多逻辑一条 SQL 搞定
  5. 执行后验证,SELECT 确认结果
相关推荐
睡不醒男孩03082315 小时前
第二篇:深入探索开源数据库高可用:构建基于CLup的PostgreSQL生产级高可用与读写分离架构
数据库·postgresql·开源·clup
Micro麦可乐17 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
码农阿豪18 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通18 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..18 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
cfm_291419 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis
真实的菜20 小时前
Redis 从入门到精通(十二):典型业务场景实战 —— 排行榜、限流器、秒杀系统、Session 共享
数据库·redis·python
你想考研啊20 小时前
mysql数据库导出导入
数据库·mysql·oracle
十年编程老舅21 小时前
Linux DRM:底层逻辑与实践架构
数据库·mysql
The Sheep 202321 小时前
Vue复习
linux·服务器·数据库