MySQL中DELETE后立刻获知删除行数应调用ROW_COUNT(),它返回上一条DML实际变更行数;PostgreSQL则需用RETURNING子句或客户端API获取影响行数。MySQL里DELETE后怎么立刻知道删了几行直接查ROW_COUNT(),不是SELECT COUNT(*)回查,也不是看客户端返回的"Query OK"模糊提示。它返回的是上一条DELETE(或UPDATE/INSERT)实际变更的行数,精确到个位。常见错误是执行完DELETE FROM t WHERE x = 1就以为完事了,结果发现没删成------可能条件写错、事务没提交、或者根本没匹配到数据。这时候ROW_COUNT()返回0,就是最直接的信号。必须在同一线程/连接中紧接DELETE之后调用,跨语句或换连接就失效存储过程中可用SELECT ROW_COUNT();应用层如Python用cursor.rowcount(注意:部分驱动需在execute()后立即读,不能先fetch)如果DELETE带LIMIT,ROW_COUNT()返回的是实际删除行数,不是LIMIT值PostgreSQL没有ROW_COUNT()函数,怎么办PostgreSQL不用函数,靠RETURNING子句或客户端API获取影响行数。它不提供类似MySQL的会话级计数器,所以得从执行动作本身拿反馈。典型场景:你想确认DELETE FROM orders WHERE status = 'canceled' AND created_at 到底清了几单,又不想再跑一遍<code>SELECT COUNT(*)------那就在删的时候加RETURNING id,然后数结果集行数。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
范范@6 分钟前
day2-python基础语法编码者卢布9 分钟前
【Azure Container App】容器应用的维护窗口设置夏至春来-美美16 分钟前
python 使用pytest的ini配置geovindu21 分钟前
python: Mutex PatternC137的本贾尼24 分钟前
告别硬编码:提示词模板入门星纬智联技术25 分钟前
给 Amp 配置自定义 API:CLIProxyAPI 接入教程m0_3722570226 分钟前
RRF和Cross-Encoder rerank怎么实现浩~~32 分钟前
极客大挑战2019-LoveSQLCosolar36 分钟前
大模型应用开发面试 • 每日三题|Day 002|记忆(Memory)、工具使用(Tool Use)和微调(Fine-tuning)码农阿豪38 分钟前
Go 语言操作金仓数据库(上篇):环境搭建与连接管理