mysql進階(二十一)刪除表數據

黄舟
發布: 2017-02-11 10:45:25
原創
1508 人瀏覽過

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中文網(www.php.cn)!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!