mysql 刪除沒有該條件的數據?從其他數據表更新該資數據的值到另一個數據表?

問題
A數據表欄位為 post_id
B數據表的欄位為 url
A跟B都有很多數據
A跟B有些 post_id 跟 url 是相符的 ,有些是不相符的 (A跟B有關聯性的字段是 post_id 跟 url )
如何把不相符的都刪除?只留下有關聯性的

DELETE a, b FROM   
`a`   
JOIN `b` ON b.ID != a.post_id這樣卻失敗了....?

mariaDB 報錯誤:

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'JOIN b ON b.ID != a.post_id' at line 3

然後又說

a, b 這一段是預期以外的符號?

PS:

  • 我要刪的是兩個資料表,只要都有不符合就刪除該筆

  • 我確定有 SELECT 到非常多不相符的數據,也有相符的數據。

  • a 的 post_id 有多個,例如b.ID 假如等於 123 那 a.post_id 有一個或多個123


慕桂英3389331
浏览 454回答 1
1回答

12345678_0001

你应该先通过A left join B,清除掉A表。再使用B left join A清理掉B表。或者使用inner join 取出。然后采用not in的方式去处理。当然这种方式效率更低。另外,在执行delete操作前,请务必备份数据,避免造成不必要的损失。
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

MySQL