Mysql INSERT ... ON DUPLICATE KEY UPDATE 记录不存在时插入,存在更新

一个推荐菜品表中目前已有的四个字段:
id(主键,自增长)
shop_id
menu_id(判断记录是否存在的字段)
last_update
status
如果新插入的记录中字段menu_id是重复的,需要更新last_update和status
在使用insert ... on duplicate key update的时候,insert 操作会在UNIQUE index和PRIMARY KEY上判断value是否重复
顺便一提,如果使用navicat设置UNIQUE,表,右键->设计表->索引,如下所示:

Mysql INSERT ... ON DUPLICATE KEY UPDATE 记录不存在时插入,存在更新_第1张图片
navicat设置字段设置UNIQUE

SQL 文:

INSERT INTO t (
    shop_id,
    menu_id,
    last_update,
    status
)
VALUES
    (
        #{item.shopId}, #{item.menuId}, NOW(), '1'
    ) ON DUPLICATE KEY UPDATE
       status = '1',
       last_update = now()

对于目前的要求,上面的SQL文已经可以实现。
有关INSERT ... ON DUPLICATE KEY UPDATE 更详细的信息,参照Mysql官方文档:
INSERT ... ON DUPLICATE KEY UPDATE 文档

你可能感兴趣的:(Mysql INSERT ... ON DUPLICATE KEY UPDATE 记录不存在时插入,存在更新)