


How to Perform Conditional Updates in INSERT ... ON DUPLICATE KEY UPDATE Statements?
Oct 30, 2024 pm 10:46 PMINSERT ... ON DUPLICATE KEY UPDATE: Conditional Updates
When performing an INSERT ... ON DUPLICATE KEY UPDATE operation, it is sometimes necessary to conditionally execute the update based on specific conditions. However, the WHERE clause is not permitted with the UPDATE portion of this statement.
Workaround Using IF()
To achieve conditional updates, one solution is to utilize the IF() function. By evaluating a condition within the IF() expression, you can specify a different value for the updated column based on the outcome.
Example
Consider the following table:
CREATE TABLE daily_events ( created_on DATE, last_event_id INT, last_event_created_at DATETIME );
To conditionally update the last_event_id column only if the last_event_created_at column has changed, you can use the following query:
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);
In this query, the IF() function checks whether the value of last_event_created_at in the database is less than the value being inserted. If true, the last_event_id is updated to the inserted value; otherwise, the existing value is retained.
Replication Compatibility
This approach is compatible with replication, as it does not involve any additional queries or modifications to the database schema.
The above is the detailed content of How to Perform Conditional Updates in INSERT ... ON DUPLICATE KEY UPDATE Statements?. For more information, please follow other related articles on the PHP Chinese website!

Hot Article

Hot tools Tags

Hot Article

Hot Article Tags

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Reduce the use of MySQL memory in Docker

How do you alter a table in MySQL using the ALTER TABLE statement?

How to solve the problem of mysql cannot open shared library

Run MySQl in Linux (with/without podman container with phpmyadmin)

What is SQLite? Comprehensive overview

Running multiple MySQL versions on MacOS: A step-by-step guide

How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)?

How do I configure SSL/TLS encryption for MySQL connections?
