SQL批量删除不同条件的记录_使用IN子句简化删除逻辑

DELETE必须配合WHERE使用,正确语法为DELETE FROM table_name WHERE column_name IN (...);直接DELETE FROM table_name IN (...)是语法错误。DELETE + IN 子句能批量删多条件记录,但必须加 WHERE 限定不加 WHERE 的 DELETE FROM table_name IN (...) 是语法错误------IN 不能直接跟在 DELETE 后面。正确写法永远是 DELETE FROM table_name WHERE column_name IN (...)。常见错误是把 IN 当成独立操作符,结果执行成全表删除或报错 ERROR 1064 (42000)。适用场景:要删一批已知主键或唯一标识的记录,比如后台运营导出需下架的 200 个商品 ID,或日志表中指定用户 ID 的操作记录。只对单列使用 IN 最稳妥;多列组合条件(如 (user_id, status))得用 JOIN 或子查询,别硬套 ININ 列表长度受 max_allowed_packet 和 MySQL 版本限制;MySQL 5.7 默认支持约 1000 项,超了会截断或报错 ERROR 1390 (HY000)如果 ID 来源是另一张表,优先写 DELETE t1 FROM table1 t1 JOIN table2 t2 ON t1.id = t2.target_id,比先查再拼 IN 更安全、更少网络传输IN 列表里 NULL 会导致整条 WHERE 失效WHERE id IN (1, 2, NULL, 4) 实际等价于 WHERE id = 1 OR id = 2 OR id = NULL OR id = 4,而 id = NULL 永远为 UNKNOWN,整个逻辑表达式可能不匹配任何行------不是删多了,而是删少了,且毫无提示。典型来源:从程序传参时没过滤空值,或前端提交了未填的下拉框、后端又用了 array_filter(ids, 'strlen') 这类只清空字符串不处理 null 的逻辑。PHP 中用 array_filter(ids, function(v) { return v !== null && $v !== ''; }) 显式剔除 nullPython 中用 x for x in ids if x is not None and x != ''SQL 层补救:加 AND id IS NOT NULL,即 WHERE id IN (...) AND id IS NOT NULL大批量删用 IN 容易锁表或超时删 10 万行时,WHERE id IN (...) 仍是一条语句,MySQL 会尝试一次性加锁、生成执行计划、写 binlog。在高并发写入的表上,可能触发 Lock wait timeout exceeded 或拖慢其他查询。 Cleanup.pictures 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

相关推荐
abcy0712134 分钟前
sqlalchemy 原生sql判断条件是否为空,为空则跳过
开发语言·python
知识分享小能手6 分钟前
数据预处理入门学习教程,从入门到精通, 实战演练——数据分析师岗位分析知识点详解(8)
python·学习·信息可视化
Wonderful U6 分钟前
Python+Django实战:打造智能生鲜果蔬进销存管理系统(采购入库、库存预警、销售开单、毛利统计)
数据库·python·django
yuhuofei202110 分钟前
【Python入门】Python中的集合set
python
Demon1_Coder11 分钟前
Day4-微服务-Seata默认事务
java·数据库·微服务
我是大猴子16 分钟前
Redis为什么不适合做持久化和DB的区别在哪里
数据库·redis·缓存
mN9B2uk1718 分钟前
数据库锁总结
数据库·oracle
大雨淅淅25 分钟前
【机器人】ROS2 机械臂控制(MoveIt2)从入门到实战
人工智能·python·神经网络·学习·算法·机器学习·机器人
闪电悠米25 分钟前
黑马点评-秒杀优化-04_lua_and_db_fallback
服务器·开发语言·网络·数据库·缓存·junit·lua
Jun62644 分钟前
QT(5)-第三方日志系统
开发语言·数据库·qt