首页 >数据库 >mysql教程 >如何使用 INSERT ... ON DUPLICATE KEY UPDATE 有条件地更新数据?

如何使用 INSERT ... ON DUPLICATE KEY UPDATE 有条件地更新数据?

Barbara Streisand
Barbara Streisand原创
2024-10-29 17:07:02646浏览

How to Update Data Conditionally with INSERT ... ON DUPLICATE KEY UPDATE?

条件 INSERT ... ON DUPLICATE KEY UPDATE

使用 INSERT ... ON DUPLICATE KEY UPDATE 时,可能需要申请有条件地更新,仅当满足特定条件时。但是,不支持在 UPDATE 子句中使用 WHERE。

使用 IF() 的解决方法

要克服此限制,可以使用 IF( ) 函数来评估条件并确定是否应执行更新。以下语法说明了此解决方法:

INSERT INTO table_name (column1, column2)
VALUES (value1, value2)
ON DUPLICATE KEY UPDATE
  column2 = IF(condition, new_value, old_value);

示例:

考虑以下场景:

INSERT INTO daily_events (created_on, last_event_id, last_event_created_at)
  VALUES ('2010-01-19', 23, '2010-01-19 10:23:11')
ON DUPLICATE KEY UPDATE
  last_event_id = IF(last_event_created_at < VALUES(last_event_created_at), VALUES(last_event_id), last_event_id);

在此示例中,更新仅当传入行中的last_event_created_at 值晚于数据库中的现有值时,才会发生to last_event_id。这可确保记录最近的事件。

以上是如何使用 INSERT ... ON DUPLICATE KEY UPDATE 有条件地更新数据?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn