MySQL 根据条件多值更新的实现

 更新时间:2025年03月14日 09:25:19   作者:王小工  
本文主要介绍了MySQL 根据条件多值更新的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

MySQL多条件批量更新核心语法:

UPDATE 表名
SET 
    字段1 = CASE 
        WHEN 条件1 THEN 值1
        WHEN 条件2 THEN 值2
        ELSE 字段1 
    END,
    字段2 = CASE 
        WHEN 条件1 THEN 值3
        WHEN 条件2 THEN 值4
        ELSE 字段2
    END
WHERE 整体过滤条件;

示例场景:更新商品库存和价格

 
UPDATE products
SET
    stock = CASE 
        WHEN category_id = 5 AND price > 100 THEN stock - 10
        WHEN create_date < '2024-01-01' THEN stock + 5
        ELSE stock
    END,
    price = CASE 
        WHEN category_id = 5 THEN price * 0.9
        WHEN stock > 1000 THEN price * 0.8
        ELSE price
    END
WHERE status = 'active';

高效写法技巧:

  • 批量更新逻辑
UPDATE users
SET 
    vip_level = CASE
        WHEN score >= 1000 THEN 'Diamond'
        WHEN score >= 500 THEN 'Gold'
        ELSE vip_level
    END,
    discount = CASE 
        WHEN score >= 1000 THEN 0.7
        WHEN score >= 500 THEN 0.8
        ELSE discount
    END
WHERE registration_year = 2024;

关键注意事项:

  • 条件优先级:WHEN子句按书写顺序匹配
  • 必须包含ELSE:防止意外覆盖数据,建议保留原值
  • 性能优化:WHERE子句需使用索引字段
  • 事务处理:大批量更新建议分批次执行
  • 多表关联:可用JOIN实现跨表条件更新
UPDATE orders o
JOIN payments p ON o.id = p.order_id
SET 
    o.status = CASE 
        WHEN p.paid = 1 THEN 'completed'
        ELSE 'pending'
    END,
    p.processed_at = NOW()
WHERE o.create_date > '2024-06-01';

扩展方案:使用IF函数简化二元判断

UPDATE employees
SET
    salary = IF(performance > 90, salary * 1.2, salary),
    bonus = IF(join_year < 2020, bonus + 5000, bonus)
WHERE department = 'Engineering';

建议根据实际数据量添加事务控制(BEGIN/COMMIT)和分页更新(LIMIT),避免长时间锁表。

到此这篇关于MySQL 根据条件多值更新的实现的文章就介绍到这了,更多相关MySQL 多值更新内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Mysql8.0不存在mysql.proc表的解决

    Mysql8.0不存在mysql.proc表的解决

    MySQL 8.0中官方移除了proc表,MySQL 5.7版本中还是存在proc表的,本文就介绍MySQL 8.0的替代方案,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • Mysql主从GTID与binlog如何使用

    Mysql主从GTID与binlog如何使用

    MySQL的GTID和binlog是实现高效数据复制和恢复的重要机制,GTID保证事务的唯一标识,避免复制冲突;binlog记录数据变更,用于主从复制和数据恢复,两者配合,提高MySQL复制的准确性和管理便捷性
    2024-10-10
  • MySQL学习第二天 安装和配置mysql winx64

    MySQL学习第二天 安装和配置mysql winx64

    MySQL学习第二天,主要为大家详细介绍了在Windows 64位操作系统下安装和配置MySQL的具体步骤,整理一份mysql winx64安装配置方法教程,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • mysql数据类型和字段属性原理与用法详解

    mysql数据类型和字段属性原理与用法详解

    这篇文章主要介绍了mysql数据类型和字段属性,结合实例形式分析了mysql数据类型和字段属性基本概念、原理、分类、用法及操作注意事项,需要的朋友可以参考下
    2020-04-04
  • Centos7系统下Mysql主从同步配置方案

    Centos7系统下Mysql主从同步配置方案

    这篇文章主要给大家介绍了关于Centos7系统下Mysql主从同步配置的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • MySQL实现批量推送数据到Mongo

    MySQL实现批量推送数据到Mongo

    这篇文章主要为大家详细介绍了MySQL如何实现批量推送数据到Mongo,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的可以了解一下
    2023-05-05
  • mysql服务器CPU利用率过高排查过程

    mysql服务器CPU利用率过高排查过程

    文章介绍了通过监控平台发现MySQL服务器CPU利用率过高的问题,通过排查和分析,找到一条执行时间过长的SQL语句,并通过EXPLAIN分析和优化该SQL,最终解决了CPU利用率过高的问题
    2025-12-12
  • mysql的join查询和多次查询方式比较

    mysql的join查询和多次查询方式比较

    这篇文章主要介绍了mysql的join查询和多次查询方式的比较,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • mysql数据库您要的常见日期查询方法总结

    mysql数据库您要的常见日期查询方法总结

    这篇文章主要介绍了MySQL中常用日期查询的20种方法,包括查询今天、昨天、近7天、近30天等数据,以及查询特定日期的周、月、季度和年份数据,需要的朋友可以参考下
    2025-02-02
  • MySQL报错1118,数据类型长度过长问题及解决

    MySQL报错1118,数据类型长度过长问题及解决

    在使用MySQL过程中,常见的一个问题是报错1118,这通常发生在创建表时,错误提示为“Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. This includes storage overhead, check the manual
    2024-10-10

最新评论