MySQL刪除表格資料
在MySQL中有兩種方法可以刪除數據,一種是DELETE語句,另一種是TRUNCATE TABLE語句。 DELETE語句可以透過WHERE對要刪除的記錄進行選擇。而使用TRUNCATE TABLE將刪除表中的所有記錄。因此,DELETE語句更靈活。
如果要清空表中的所有記錄,可以使用下面的兩種方法:
DELETE FROM table1
TRUNCATE TABLE table1
登入後複製
若要刪除表格中的部分記錄,只能使用DELETE語句。
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語句選擇要刪除的記錄,但執行速度不快。
truncate刪除後不記錄mysql日誌,無法復原資料。 delete的效果有點像是將mysql表中所有記錄一筆一條刪除到刪完,而truncate相當於保留mysql表的結構,重新建立了這個表,所有的狀態都相當於新表。而且還可以傳回被刪除的記錄數。而TRUNCATE TABLE無法刪除指定的記錄,而且不能傳回被刪除的記錄。但它執行得非常快。
和標準的SQL語句不同,DELETE支援ORDER BY和LIMIT子句,透過這兩個子句,我們可以更好地控制要刪除的記錄。如當我們只想刪除WHERE子句過濾出來的記錄的一部分,可以使用LIMIT,如果要刪除後幾筆記錄,可以透過ORDER BY和LIMIT來搭配使用。假設我們要刪除users表中name等於"Mike"的前6筆記錄。可以使用以下的DELETE語句:
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中文網(m.sbmmt.com)!