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 JOINLEFT JOIN和连接条件。JOIN子句必须出现在UPDATE子句之后。
  • 第三,要为要更新的T1和/或T2表中的列分配新值。
  • 第四,WHERE子句中的条件用于指定要更新的行。
使用INNER JOIN子句的MySQL UPDATE JOIN示例

假设想根据员工的工作表现来调整员工的工资。
因此,优点百分比存储在 merits 表中,必须使用 UPDATE INNER JOIN 语句根据存储在 merits 表中的百分比来调整 employees 表中员工的工资。
employeesmerits 表之间以是 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必知必会》]