MySQL多表刪除方法是我們經常需要使用到的,具有很高的使用價值,下面就為您詳述該方法的實現過程,希望對您能夠有所幫助。
MySQL多表刪除:
第一個多表刪除格式從 MySQL 4.0.0 開始被支持。第二個多表刪除格式從 MySQL 4.0.2 開始被支持。
僅僅在 FROM 或 USING 子句 之前 列出的表中的匹配記錄行被刪除。效果就是,你要以從多個表中同時刪除記錄行,並且同樣可以有其它的表用於檢索。
在表名後的 .* 僅僅是為了兼容 Access:
DELETE t1,t2 FROM t1,t2,t3 WHERE t1.id=t2.id AND t2.id=t3.id
or
DELETE FROM t1,t2 USING t1,t2,t3 WHERE t1.id=t2.id AND t2.id=t3.id
在上面的情況下,我們僅僅從 t1 和 t2 表中刪除匹配的記錄行。
如果一個 ORDER BY 子句被使用(從 MySQL 4.0.0 開始支持), 記錄行將以指定的次序刪除。這實際上只有連同 LIMIT 一起才有用。示例如下:
DELETE FROM somelog
WHERE user = 'jcole'
ORDER BY timestamp
LIMIT 1
這將刪除匹配 WHERE 子句的,並且最早被插入(通過 timestamp 來確定)的記錄行。
DELETE 語句的LIMIT rows 選項是 MySQL 特有的,它告訴服務器在控制權被返回到客戶端之前可被刪除的最大記錄行數目。這可以用來確保一個特定的 DELETE 命令不會占用太長的時間。你可以簡單地重復使用 DELETE 命令,直到被影響的記錄行數目小於 LIMIT 值。
從 MySQL 4.0 開始,在 DELETE 語句中可以指定多個表,用以從一個表中刪除依賴於多表中的特殊情況的記錄行。然而,在一個MySQL多表刪除中,不能使用 ORDER BY 或 LIMIT。