我正在尝试从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 回答
![?](http://img1.sycdn.imooc.com/5458502c00012d4a02200220-100-100.jpg)
蛊毒传说
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
)
- 1 回答
- 0 关注
- 160 浏览
添加回答
举报
0/150
提交
取消