在MySQL中有兩種方法可以刪除數據,一種是DELETE語句,另一種是TRUNCATE TABLE語句。 DELETE語句可以透過WHERE對要刪除的記錄進行選擇。而使用TRUNCATE TABLE將刪除表中的所有記錄。因此,DELETE語句更靈活。
如果要清空表中的所有記錄,可以使用下面的兩種方法:
DELETE FROM table1 TRUNCATE TABLE table1
DELETE FROM table1 WHERE ...;如果DELETE不加WHERE子句,那麼它和TRUNCATE TABLE是一樣的,但它們有一點不同,那就是DELETE可以回傳被刪除的記錄數,而TRUNCATE TABLE回傳的是0。
如果一個表中有自增字段,使用TRUNCATE TABLE和沒有WHERE子句的DELETE刪除所有記錄後,這個自增字段將起始值恢復成1.如果你不想這樣做的話,可以在DELETE語句中加上永真的WHERE,如WHERE 1或WHERE true。
DELETE FROM table1 WHERE 1;上面的語句在執行時將掃描每一筆記錄。但它並不比較,因為這個WHERE條件永遠是true。雖然這樣做可以保持自增的最大值,但由於它是掃描了所有的記錄,因此,它的執行成本比沒有WHERE子句的DELETE大得多。
DELETE和TRUNCATE TABLE的最大差異是DELETE可以透過WHERE語句選擇要刪除的記錄,但執行速度不快。
DELETE FROM users WHERE name = 'Mike' LIMIT 6;一般MySQL並不確定刪除的這6筆記錄是哪6條,為了更保險,我們可以使用ORDER BY對記錄進行排序。
DELETE FROM users WHERE name = 'Mike' ORDER BY id DESC LIMIT 6;
美文美圖
以上就是mysql進階(二十一)刪除表格資料 的內容,更多相關內容請追蹤PHP中文網(www.php.cn)!