【高效运维必备】5种方法实现MySQL多列日期同步更新

📌 场景痛点:
当遇到会员有效期、服务周期、数据版本等需要批量更新日期字段时,如何精准控制日期部分而保留原始时间?今天教你一套DBA都在用的高效解决方案!


一、基础版 - DATE_ADD函数法(推荐指数⭐⭐⭐⭐⭐)

UPDATE user_subscription 
SET 
    expire_date = DATE_ADD(expire_date, INTERVAL DATEDIFF('2023-09-01', DATE(expire_date)) DAY),
    last_renew = DATE_ADD(last_renew, INTERVAL DATEDIFF('2023-09-01', DATE(last_renew)) DAY)
WHERE user_type = 'VIP';

✔️ 原理:通过计算新旧日期差值,仅修改日期部分


二、进阶版 - 时间拼接法(跨时区场景适用)

UPDATE audit_log 
SET 
    start_time = STR_TO_DATE(CONCAT('2023-09-01 ', TIME(start_time)), '%Y-%m-%d %H:%i:%s'),
    end_time = STR_TO_DATE(CONCAT('2023-09-01 ', TIME(end_time)), '%Y-%m-%d %H:%i:%s') 
WHERE log_month = 8;

🔥 亮点:完美解决日期时间分离需求,特别适合跨天日志处理


三、条件更新法 - CASE语句实战







次阅读

扫描下方二维码,关注公众号:程序进阶之路,实时获取更多优质文章推送。


扫码关注

评论