mysql upsert 例子_MySQL upsert与额外检查

我想使用INSERT … ON DUPLICATE KEY UPDATE进行一些复杂的upsert操作.但我无法让它发挥作用.

这就是我想做的事情:

>尝试插入记录.如果插入成功,那很好.

>如果该记录存??在,请更新记录.

>更新记录时,如果check_status字段为1,则保留描述和注释字段.

>更新记录时,check_status字段为0,然后更新描述和注释字段.

在写出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(描述)会在DB表中给出现有记录(即“现有描述”)的值.但是,它似乎给了我试图插入的内容,即“一些描述”.

有没有人知道如何使用SQL正确地做到这一点.尝试upsert时,引用现有记录中的值的最佳方法是什么?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值