为了账号安全,请及时绑定邮箱和手机立即绑定

MySQL不允许我删除记录

MySQL不允许我删除记录

PHP
长风秋雁 2021-05-10 20:21:30
我正在尝试从PHP执行此MySQL子句$conn = new mysqli($servername, $username, $password, $dbname);$sql = "DELETE FROM table_2 WHERE id in (select DISTINCT(id) FROM table_2 WHERE id NOT IN (SELECT id FROM table_2 WHERE p = 1 AND r =1))";if ($conn->query($sql) === TRUE) {    echo "Record deleted successfully";} else {    echo "Error deleting record: " . $conn->error;}我收到以下错误删除记录时出错:您无法在FROM子句中指定目标表“ table_2”进行更新我究竟做错了什么?
查看完整描述

1 回答

?
蛊毒传说

TA贡献1895条经验 获得超3个赞

您可以使用子查询来绕过MySQL的这一限制,但是您的语句可以像这样简化:


DELETE FROM table_2 

WHERE id NOT IN (

  SELECT id FROM (

    SELECT id FROM table_2 WHERE p = 1 AND r = 1

  ) t


查看完整回答
反对 回复 2021-05-21
  • 1 回答
  • 0 关注
  • 160 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信