1 UPDATE
为了更新(修改)表中的数据,可使用UPDATE语句。可采用两种方式使用UPDATE:
- 更新表中特定行
- 更新表中所有行
注意:
-
不要省略WHERE子句
,在使用UPDATE时一定要注意细心。因为稍不注意,就会更新表中所有行。 -
UPDATE与安全
,可以限制和控制UPDATE语句的使用。
UPDATE语句由三部分组成,分别是:
- 要更新的表;
- 列名和它们的新值;
- 确定要更新行的过滤条件。
2 UPDATE常用情景
2.1 更新一个表中的某个字段
UPDATE customers
SET cust_email= ‘elmer@fudd.com’
WHERE cust_id = 10005;
2.2 更新多个列
UPDATE customers
SET cust_email= ‘elmer@fudd.com’,
cust_name= 'The Fudds'
WHERE cust_id = 10005;
2.3 跨表更新
UPDATE T1, T2,
[INNER JOIN | LEFT JOIN] T1 ON T1.C1 = T2. C1
SET T1.C2 = T2.C2,
T2.C3 = expr
WHERE condition
更详细地看看MySQL UPDATE JOIN
语法:
- 首先,在
UPDATE
子句之后,指定主表(T1)和希望主表连接表(T2)。 - 第二,指定一种要使用的连接,即
INNER JOIN
或LEFT JOIN
和连接条件。JOIN
子句必须出现在UPDATE
子句之后。 - 第三,要为要更新的T1和/或T2表中的列分配新值。
- 第四,
WHERE
子句中的条件用于指定要更新的行。
使用INNER JOIN子句的MySQL UPDATE JOIN示例
假设想根据员工的工作表现来调整员工的工资。
因此,优点百分比存储在 merits
表中,必须使用 UPDATE INNER JOIN
语句根据存储在 merits
表中的百分比来调整 employees
表中员工的工资。employees
和 merits
表之间以是 performance
字段相关联的。 请参阅以下查询:
UPDATE employees
INNER JOIN
merits ON employees.performance = merits.performance
SET
salary = salary + salary * percentage;
上面查询语句的工作原理是什么?
我们仅在 UPDATE
子句之后指定 employees
表,因为我们只想更新 employees
表中的数据。
对于 employees
表中的每一行,查询根据 merits
表中 performance
列中的值来检查 employees
表中的 performance
列中的值。 如果找到一个匹配,它将获得 merits
表中的百分比,并更新 employees
表中的 salary
列。
因为省略了 UPDATE
语句中的 WHERE
子句,所以 employees
表中的所有记录都被更新。如果需要 performance
等级大于1的员工才更新薪资,那么 sql 可以这样写:
UPDATE employees
INNER JOIN
merits ON employees.performance = merits.performance
SET
salary = salary + salary * percentage
WHERE employees.performance > 1;
2.4 UPDATE 结合 SELECT
UPDATE user_online_month_atu a
INNER JOIN (
SELECT
user_id,
sum(c.online_times) as online_times,
SUM(c.login_count) as login_count,
Sum(c.view_page_count) as view_page_count,
LEFT(c.log_date,length(c.log_date) - 2) as date
FROM
user_online_time_atu c
GROUP BY
c.user_id ,date
) b ON a.user_id = b.user_id AND a.`month`=b.date
SET a.online_time = b.online_times ,a.login_count=b.login_count,a.view_page_count=b.view_page_count
2.5 使用UPDATE 删除某列的值,设置位NULL
UPDATE customers
SET cust_email = NULL;
WHERE cust_id = 10005;
补充
IGNORE关键字:
如果由UPDATE语句更新多行,并且在更新这些行中的一行或多行时出现一个错误,则整个UPDATE操作被取消错误
(错误发生前更新的所有行被恢复到它们原来的值)。即使是发生错误,也继续进行更新,可使用IGNORE关键字,如下所示:
UPDATE IGNORE custormers...
[参考博客]
MySQL update使用select的结果mysql update select 从查询结果中更新数据 [参考书籍]
[《MySQL必知必会》]