Like Share Discussion Bookmark Smile

J.J. Huang   2020-07-13   MySQL   瀏覽次數:

MySQL - 第二十二章 | 更新和刪除資料

更新資料

為了更新(修改)表中的資料,可使用UPDATE語句。可採用兩種方式使用UPDATE:

  • 更新表中特定行;
  • 更新表中所有行。

注意:不要省略WHERE子句 在使用UPDATE時一定要注意細心。因為稍不注意,就會更新表中所有行。

提示:UPDATE與安全 事務處理(transaction processing),可以限制和控制UPDATE語句的使用;這個部分後面會再慢慢提到。

基本的UPDATE語句由3部分組成,分別是:

  • 要更新的表;
  • 列名和它們的新值;
  • 確定要更新行的過濾條件。

客戶10005現在有了電子郵件地址,因此他的記錄需要更新,語句如下:

1
2
3
mysql> UPDATE customers SET cust_email = 'test@test.com' WHERE cust_id = '10005';
Query OK, 1 row affected (0.02 sec)
Rows matched: 1 Changed: 1 Warnings: 0

分析:UPDATE語句總是以要更新的表的名字開始。在此例子中,要更新的表的名字為customers。
SET命令用來將新值賦給被更新的列。

SET子句設置cust_email列為指定的值:

1
SET cust_email = 'test@test.com'

UPDATE語句以WHERE子句結束,它告訴MySQL更新哪一行。沒有WHERE子句,MySQL將會用這個電子郵件地址更新customers表中所有行,你絕對不想發生…。

更新多個列的語法:

1
2
3
mysql> UPDATE customers SET cust_name = 'J.J.', cust_email = 'test@test.com' WHERE cust_id = '10005';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0

分析:在更新多個列時,只需要使用單個SET命令,每個”列=值”對之間用逗號分隔(最後一列之後不用逗號)。
在此例子中,更新客戶10005的cust_name和cust_email列。

提示:在UPDATE語句中使用子查詢 UPDATE語句中可以使用子查詢,使得能用SELECT語句檢索出的資料更新列資料。

提示:IGNORE關鍵字 如果用UPDATE語句更新多行,並且在更新這些行中的一行或多行時出一個現錯誤,則整個UPDATE操作被取消(錯誤發生前更新的所有行被恢復到它們原來的值)。為即使是發生錯誤,也繼續進行更新,可使用IGNORE關鍵字。

如下所示:

1
UPDATE IGNORE customers...

為了刪除某個列的值,可設置它為NULL(假如表定義允許NULL值)。

1
2
3
mysql> UPDATE customers SET cust_email = NULL WHERE cust_id = '10005';
Query OK, 1 row affected (0.02 sec)
Rows matched: 1 Changed: 1 Warnings: 0

刪除資料

為了從一個表中刪除(去掉)資料,使用DELETE語句。可以兩種方式使用DELETE:

  • 從表中刪除特定的行;
  • 從表中刪除所有行。

注意:不要省略WHERE子句 在使用DELETE時一定要注意細心。因為稍不注意,就會錯誤地刪除表中所有行。

提示:DELETE與安全 務處理(transaction processing),可以限制和控制DELETE語句的使用;這個部分後面會再慢慢提到。

UPDATE非常容易使用,而DELETE更容易使用。

1
DELETE FROM customers WHERE cust_id = '10005';

分析:DELETE FROM要求指定從中刪除資料的表名。WHERE子句過濾要刪除的行。在這個例子中,只刪除客戶10006。如果省略WHERE子句,它將刪除表中每個客戶。

DELETE不需要列名或通配符。DELETE刪除整行而不是刪除列。為了刪除指定的列,請使用UPDATE語句。

說明:刪除表的內容而不是表 DELETE語句從表中刪除行,甚至是刪除表中所有行。但是,DELETE不刪除表本身。

提示:更快的刪除 如果想從表中刪除所有行,不要使用DELETE。可使用TRUNCATE TABLE語句,它完成相同的工作,但速度更快(TRUNCATE實際是刪除原來的表並重新創建一個表,而不是逐行刪除表中的資料)。

更新和刪除的指導原則

UPDATE和DELETE語句全都具有WHERE子句,這樣做的理由很充分。如果省略了WHERE子句,則UPDATE或DELETE將被應用到表中所有的行。換句話說,如果執行UPDATE而不帶WHERE子句,則表中每個行都將用新值更新。類似地,如果執行DELETE語句而不帶WHERE子句,表的所有資料都將被刪除。

面是許多SQL程序員使用UPDATE或DELETE時所遵循的習慣:

  • 除非確實打算更新和刪除每一行,否則絕對不要使用不帶WHERE子句的UPDATE或DELETE語句。
  • 保證每個表都有主鍵(如果忘記這個內容),盡可能 像WHERE子句那樣使用它(可以指定各主鍵、多個值或值的範圍)。
  • 在對UPDATE或DELETE語句使用WHERE子句前,應該先用SELECT進行測試,保證它過濾的是正確的記錄,以防編寫的WHERE子句不正確。
  • 使用強制實施引用完整性的資料庫,這樣MySQL將不允許刪除具有與其他表相關聯的資料的行。

注意:小心使用 MySQL沒有撤銷(undo)按鈕。應該非常小心地使用UPDATE和DELETE,否則你會發現自己更新或刪除了錯誤的資料。

結語

在使用UPDATE和DELETE,一定要保持良好習慣啊,不然出狀況一定會後悔當初沒做備份或是多做檢查。這邊比較需要知道的部分就是可使用TRUNCATE TABLE語句,它完成相同的工作,但速度更快(TRUNCATE實際是刪除原來的表並重新創建一個表,而不是逐行刪除表中的資料)。

註:以上參考了
MySQL必知必会 MySQL Crash Course