MySQL 中的 UPDATE 语句详解

 更新时间:2025年05月20日 15:59:17   作者:BirdMan98  
UPDATE 语句用于修改表中的数据,可以更新单行或多行数据,下面给大家介绍MySQL 中的 UPDATE 语句,感兴趣的朋友一起看看吧

MySQL 中的 UPDATE 语句

UPDATE 语句用于修改表中的数据,可以更新单行或多行数据。

1. UPDATE 语法

UPDATE 表名
SET 列1 = 值1, 列2 = 值2, ...
WHERE 条件;

⚠ 注意

  • 必须加 WHERE,否则会修改所有行。
  • SET 后可同时更新多个字段。
  • WHERE 用于筛选需要更新的记录

2. 基本 UPDATE

示例

(1) 更新单个字段

UPDATE users
SET age = 30
WHERE id = 1;

解释

id = 1age 更新为 30

(2) 更新多个字段

UPDATE users
SET age = 30, city = 'Shanghai'
WHERE id = 1;

解释

id = 1age 改为 30city 改为 'Shanghai'

(3) 更新所有行(小心使用!)

UPDATE users SET status = 'inactive';

⚠ 危险

  • 没有 WHERE,会更新整个表!
  • status 字段的所有数据都变成 'inactive'

如何防止误操作?

先用 SELECT 检查更新范围

SELECT * FROM users WHERE status = 'active';

开启事务(如果支持)

START TRANSACTION;
UPDATE users SET status = 'inactive';
ROLLBACK;  -- 取消
COMMIT;    -- 确认更新

3. UPDATE 结合 WHERE 条件

(1) 使用 = 精确匹配

UPDATE users SET age = 25 WHERE name = 'Alice';

更新 name = 'Alice' 的用户的 age25

(2) 使用 ANDOR

UPDATE users
SET status = 'inactive'
WHERE age > 30 AND city = 'Beijing';

更新 age > 30 且 city = 'Beijing' 的用户。

UPDATE users
SET status = 'inactive'
WHERE age > 50 OR city = 'Shanghai';

更新 age > 50city = 'Shanghai' 的用户。

(3) 使用 IN

UPDATE users
SET vip_status = 'gold'
WHERE id IN (1, 2, 3, 5);

更新 id(1,2,3,5) 里的用户。

(4) 使用 BETWEEN

UPDATE users
SET level = 'senior'
WHERE age BETWEEN 30 AND 40;

更新 age30-40 之间的用户。

(5) 使用 LIKE

UPDATE users
SET department = 'Tech'
WHERE email LIKE '%@gmail.com';

更新所有 email@gmail.com 结尾的用户。

4. UPDATE 结合 JOIN

批量更新数据,通过 JOIN 关联两个表:

UPDATE users u
JOIN orders o ON u.id = o.user_id
SET u.vip_status = 'gold'
WHERE o.total_amount > 1000;

解释

  • users 表和 orders 表通过 user_id 关联。
  • 当用户的 total_amount > 1000 时,更新 users.vip_status'gold'

5. UPDATE 结合 CASE(条件更新)

UPDATE users
SET vip_status = 
    CASE 
        WHEN age > 50 THEN 'platinum'
        WHEN age BETWEEN 30 AND 50 THEN 'gold'
        ELSE 'silver'
    END;

解释

  • age > 50platinum
  • age 在 30-50 之间 → gold
  • 其他情况 → silver

6. UPDATE 结合 LIMIT

如果一次只想修改 部分数据

UPDATE users SET status = 'inactive' ORDER BY id ASC LIMIT 10;

解释

  • 只更新 前 10 行 数据(按 id 升序排序)。
  • 适用于大表分批更新

7. UPDATE 结合 ORDER BY

更新时,按特定顺序处理数据:

UPDATE users SET rank = rank + 1 ORDER BY age DESC;

解释

age 从大到小更新 rank

8. UPDATE 批量替换字段

(1) 替换部分字符串

UPDATE users
SET email = REPLACE(email, 'gmail.com', 'yahoo.com')
WHERE email LIKE '%gmail.com';

解释

email 里的 gmail.com 替换为 yahoo.com

(2) 拼接字符串

UPDATE users
SET username = CONCAT(username, '_new');

解释

username 末尾加 _new

9. UPDATE 事务控制

如果 UPDATE 可能影响多行数据,建议使用事务

START TRANSACTION;
UPDATE users SET balance = balance - 100 WHERE id = 1;
UPDATE users SET balance = balance + 100 WHERE id = 2;
COMMIT;

如果失败,可回滚

ROLLBACK;

10. 防止 UPDATE 影响整个表

为了防止忘记 WHERE 语句,可以开启 safe updates

SET SQL_SAFE_UPDATES = 1;

如果更新时没加 WHERE,会报错:

ERROR 1175 (HY000): You are using safe update mode...

关闭(仅当必要时):

SET SQL_SAFE_UPDATES = 0;

总结

用法说明示例
更新单列修改一个字段UPDATE users SET age = 30 WHERE id = 1;
更新多列同时修改多个字段UPDATE users SET age = 30, city = 'Shanghai' WHERE id = 1;
批量更新更新多个匹配行UPDATE users SET status = 'inactive' WHERE age > 30;
UPDATE ... JOIN关联更新UPDATE users u JOIN orders o ON u.id = o.user_id SET u.vip_status = 'gold' WHERE o.total_amount > 1000;
UPDATE ... CASE条件更新UPDATE users SET vip_status = CASE WHEN age > 50 THEN 'platinum' ELSE 'silver' END;
UPDATE ... LIMIT限制更新行数UPDATE users SET status = 'inactive' ORDER BY id ASC LIMIT 10;
UPDATE ... REPLACE替换字段内容UPDATE users SET email = REPLACE(email, 'gmail.com', 'yahoo.com');

🚀 重点

  • 一定要加 WHERE,避免误更新所有数据!
  • 批量更新大表时,分批更新 (LIMIT),避免锁表。
  • 用 CASE 进行条件更新,提高灵活性。
  • 涉及多个表时,用 JOIN 更新数据。
  • 大规模更新前,先 SELECT 预览结果。

这样,你的 UPDATE 语句就能又快又安全!💡

到此这篇关于MySQL 中的 UPDATE 语句的文章就介绍到这了,更多相关mysql update语句内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 浅谈MySQL数据库中日期中包含零值的问题

    浅谈MySQL数据库中日期中包含零值的问题

    下面小编就为大家带来一篇浅谈MySQL数据库中日期中包含零值的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-03-03
  • 使用RPM包安装MySQL 5.7.18的教程

    使用RPM包安装MySQL 5.7.18的教程

    这篇文章主要介绍了使用RPM包安装MySQL 5.7.18的教程,需要的朋友可以参考下
    2017-04-04
  • MySQL表分区的几种实现

    MySQL表分区的几种实现

    本文主要介绍了MySQL表分区的几种实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • MySQL服务器线程数的查看方法详解

    MySQL服务器线程数的查看方法详解

    这篇文章主要介绍了MySQL服务器线程数的查看方法,结合实例形式分析了mysql线程数查看的相关命令、配置、参数及相关使用技巧,需要的朋友可以参考下
    2018-03-03
  • 在 CentOS 7 下如何使用 Ansible Playbook 实现 MySQL 8.0.34 的二进制安装

    在 CentOS 7 下如何使用 Ansible Playbook 实现 MySQL 8.0.34 的

    要在 CentOS 7 下使用 Ansible Playbook 实现 MySQL 8.0.34 的二进制安装,需要先下载 MySQL 8.0.34 的二进制包,并将其上传至目标服务器,对MySQL 8.0.34 二进制安装过程感兴趣的朋友跟随小编一起看看吧
    2024-03-03
  • MySQL入门(三) 数据库表的查询操作【重要】

    MySQL入门(三) 数据库表的查询操作【重要】

    本节比较重要,对数据表数据进行查询操作,其中可能大家不熟悉的就对于INNER JOIN(内连接)、LEFT JOIN(左连接)、RIGHT JOIN(右连接)等一些复杂查询。 通过本节的学习,可以让你知道这些基本的复杂查询是怎么实现的,,需要的朋友可以参考下
    2018-07-07
  • 详细聊一聊mysql的树形结构存储以及查询

    详细聊一聊mysql的树形结构存储以及查询

    由于mysql是关系型数据库,因此对于类似组织架构,子任务等相关的树形结构的处理不是很友好,下面这篇文章主要给大家介绍了关于mysql树形结构存储以及查询的相关资料,需要的朋友可以参考下
    2022-04-04
  • MySQL报错Failed to open the referenced table XXX问题

    MySQL报错Failed to open the referenced&nbs

    在数据库操作中,尝试删除外键约束表'master_role'时遇到错误码3730,因其被'user_role'表中的外键'fk_user_role'引用,解决方法包括关闭外键检查和删除外键,阿里巴巴开发手册和知乎回答指出,外键虽能维护数据一致性
    2024-11-11
  • Mysql的timestamp时间戳详解及2038问题

    Mysql的timestamp时间戳详解及2038问题

    本文主要介绍了Mysql的timestamp时间戳详解及2038问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • MySQL内存使用率高且不释放问题排查与总结

    MySQL内存使用率高且不释放问题排查与总结

    这篇文章主要给大家介绍了MySQL内存使用率高且不释放问题排查与总结,文中通过代码示例和图文结合的方式给大家讲解的非常详细,对大家解决问题有一定的帮助,需要的朋友可以参考下
    2024-09-09

最新评论