[英]MySQL doesn't let me delete record
我正在尝试从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”进行更新
我究竟做错了什么?
您可以使用子查询来绕过MySQL的这一限制,但是您的语句可以像这样简化:
DELETE FROM table_2
WHERE id NOT IN (
SELECT id FROM (
SELECT id FROM table_2 WHERE p = 1 AND r = 1
) t
)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.