带有额外检查的 MySQL upsert

标签 mysql database upsert

我想使用 INSERT ... ON DUPLICATE KEY UPDATE 执行一些复杂的更新插入操作。但我无法让它工作。

这是我想做的:

  1. 尝试插入一条记录。如果插入成功,那很好。
  2. 如果该记录存​​在,则更新该记录。
  3. 更新记录时,如果check_status字段为1,则留下description和comment字段。
  4. 更新记录时,check_status字段为0,然后更新description和comment字段。

在写SQL之前,我们假设some_table中有如下记录:

column name      | val
-----------------+-------------------------
some_unique_key  | 32
description      | existing description
comment          | existing comment
check_status     | 1

所以为了完成我上面描述的操作,我使用了如下SQL:

INSERT INTO some_table ('description', 'comment', 'some_unique_key')
VALUES ('some description', 'some comment', 32)
ON DUPLICATE KEY UPDATE
description = IF(check_status = 1, VALUES(description), 'some description')
comment = IF(check_status = 1, VALUES(comment), 'some comment')

我认为 VALUES(description) 会给我数据库表中现有记录的值(即“现有描述”)。但是,它似乎给了我我试图插入的内容,即“一些描述”。

有谁知道如何使用 SQL 正确执行此操作。尝试更新插入时引用现有记录中的值的最佳方式是什么?

最佳答案

简单。不要使用 VALUES()(您已经在使用它来引用 check_status 的现有值):

INSERT INTO some_table ('description', 'comment', 'some_unique_key')
VALUES ('some description', 'some comment', 32)
ON DUPLICATE KEY UPDATE
description = IF(check_status = 1, description, 'some description')
comment = IF(check_status = 1, comment, 'some comment')

或者用它来设置新内容而不是重复自己:

INSERT INTO some_table ('description', 'comment', 'some_unique_key')
VALUES ('some description', 'some comment', 32)
ON DUPLICATE KEY UPDATE
description = IF(check_status = 1, description, VALUES(description))
comment = IF(check_status = 1, comment, VALUES(comment))

关于带有额外检查的 MySQL upsert,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14792677/

相关文章:

sql - 在Oracle中获取插入行的ID,使用序列和触发器插入ID

android - 在 Android - Market 上发布应用程序更新,无需删除本地数据库和本地文件

Spring MongoTemplate 更新插入整个对象

php - 在重复键更新时使用 insert... 更新插入

MySql upsert 和 auto-increment 导致 gaps

c# - MySql.Data.MySqlClient.MySqlException : 'Table ' performance_schema. session_variables'不存在'

MySQL子数据行有多个父键,需要构建select查询

mysql - 无法读取 MySQL 数据库中的外来字符(Xampp 和 Ruby on Rails)

PHP:如何从mysql检索数据并插入到特定用户

mysql - 计数大于总行数