MySQL不允许我删除记录

时间:2019-04-27 22:14:58

标签: php mysql

我正在尝试从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;
}

我收到以下错误

  

删除记录时出错:您无法为以下对象指定目标表“ table_2”   在FROM子句中更新

我在做什么错了?

1 个答案:

答案 0 :(得分:1)

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

DELETE FROM table_2 
WHERE id NOT IN (
  SELECT id FROM (
    SELECT id FROM table_2 WHERE p = 1 AND r = 1
  ) t
)