sql
delete from pms_pay_refund_order where pay_order_no in (select pay_order_no from pms_pay_refund_order GROUP BY pay_order_no HAVING count(pay_order_no) >1) and channel_err_msg = '申请退款金额大于可退款余额'
在 MySQL 里,若要删除子查询所涉及表中的数据,直接使用原 SQL 会报错
1093 - You can't specify target table 'pms_pay_refund_order' for update in FROM clause
下面是修正后的 SQL 语句:
sql
DELETE p1
FROM pms_pay_refund_order p1
JOIN (
SELECT pay_order_no
FROM pms_pay_refund_order
GROUP BY pay_order_no
HAVING COUNT(pay_order_no) > 1
) p2 ON p1.pay_order_no = p2.pay_order_no
WHERE p1.channel_err_msg = '申请退款金额大于可退款余额';
主要修改点
- 运用内连接(JOIN)把主表和子查询结果关联起来,防止出现 "你不能在 FROM 子句中为更新指定目标表" 的错误。
- 采用表别名(p1、p2)清晰区分主表和子查询。
- 把过滤条件
channel_err_msg = ...
放在 WHERE 子句里,精准筛选要删除的记录