MySQL之存在则更新,否则就插入数据

 更新时间:2024年01月31日 16:04:03   作者:ChengQinHong  
这篇文章主要介绍了MySQL之存在则更新,否则就插入数据问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

背景

用户获得免费电影观看权,如果同个电影获得再次获得观看权,则在领取记录中更新获取时间,如果首次获取的免费电影观看权,则新增一条获奖记录。

思考

其实是数据库的“存在则更新数据,不存在就插入数据”问题,MySQL有相应的语法可以解决,需要搭配索引。

数据表结构

CREATE TABLE `prize_order` (
  `id` int NOT NULL AUTO_INCREMENT,
  `mobile` char(11) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '手机号码',
  `order_status` int DEFAULT '0' COMMENT '受理状态,1-成功,0-失败',
  `create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `prize_id` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '奖品电影编号',
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE KEY `index_uni` (`mobile`,`prize_id`) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=19 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='订单日志表';

索引

数据

第一种insert语法(推荐!!!)

语法(此时不知道表中已有prize_id='1'的数据)

insert into prize_order (mobile,create_time,prize_id) values('15122223333','2022-10-02 00:00:00','1') on DUPLICATE key update create_time =now()

不知道表中数据的情况下,已有数据会更新,mobile='15122223333' and prize_id='1'数据会修改create_time字段=now() 

执行情况

语法(此时不知道表中无prize_id='60'的数据)

insert into prize_order (mobile,create_time,prize_id) values('15122223333',now(),'60') on DUPLICATE key update create_time = now()

不知道表中数据的情况下, 当数据不存在时,则会新增一条mobile='15122223333' ,prize_id='1',create_time字段=now() 的数据 

执行情况

第二种replace语法(个别场景下使用)

语法(此时不知道表中已有prize_id='1'的数据)

replace into prize_order(mobile,order_status,create_time,prize_id)VALUES('15122223333','1',now(),'1')

执行情况

​​​​​​​

 

语法(此时不知道表中无prize_id='20'的数据)

replace into prize_order(mobile,order_status,create_time,prize_id)VALUES('15122223333','1',now(),'20')

执行结果

 缺点

相信replace语法对很多“存在则更新,否则插入数据”的需求都满足。

我们也看到了,它会删除原数据,再进行插入数据,此时你有些字段不想更新,则被它抹除了,所以,用这个语法记得把所有需要的字段都正确赋值,不然会出现丢失数据的后果。

总结

根据以上对比,insert语法更优,推荐使用,因为不影响原有id,也只会更新所需字段,其余不处理的字段保持原有值;而replace语法则会改变id和改变除所需字段以外的值,有丢失数据的风险,建议熟悉该语法并对应业务场景才使用。

好了,以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 在MySQL中存储图片的操作步骤

    在MySQL中存储图片的操作步骤

    之前遇到一个问题,就是在将项目迁移到别的服务器的时候出现图片路径不对的问题,因为存放图片的方式是在数据库中存放图片路径,但是路径前却带了域名,所以本文将给大家介绍在MySQL中存储图片的操作步骤,需要的朋友可以参考下
    2024-04-04
  • 基于sqlalchemy对mysql实现增删改查操作

    基于sqlalchemy对mysql实现增删改查操作

    这篇文章主要介绍了基于sqlalchemy对mysql实现增删改查操作,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • MySQL与MSSQl使用While语句循环生成测试数据的代码

    MySQL与MSSQl使用While语句循环生成测试数据的代码

    有时候我们测试性能的时候经常需要生产大量的测试数据,用sql语句直接生成的数据更快,需要的朋友可以参考下。
    2010-12-12
  • MYSQL之插入极限分析

    MYSQL之插入极限分析

    MYSQL之插入极限分析,需要的朋友可以参考下
    2013-02-02
  • mysql 的indexof函数用法说明

    mysql 的indexof函数用法说明

    这篇文章主要介绍了mysql 的indexof函数用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • 简单了解SQL常用删除语句原理区别

    简单了解SQL常用删除语句原理区别

    这篇文章主要介绍了简单了解SQL常用删除语句原理区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • 深入MYSQL中的COLLATE

    深入MYSQL中的COLLATE

    MYSQL COLLATE是用于指定字符集的排序规则的关键词,它可以用于在查询中对字符数据进行排序和比较,具有一定的参考价值,感兴趣的可以了解一下
    2023-08-08
  • mysql主从库不同步问题解决方法

    mysql主从库不同步问题解决方法

    本来配置可以使用的mysql主从库同步的数据库,突然出现无法同步的情况。那么大家可以参考下面的方法解决下。
    2011-08-08
  • Mysql通过explain分析定位数据库性能问题

    Mysql通过explain分析定位数据库性能问题

    这篇文章主要介绍了Mysql通过explain分析定位数据库性能问题,明确SQL在Mysql中实际的执行过程是怎样的,如果查询字段没有索引则增加索引,如果有索引就要分析为什么没有用到索引,本文详细讲解,需要的朋友可以参考下
    2023-01-01
  • MySQL执行.sql 文件的超详细教学指南

    MySQL执行.sql 文件的超详细教学指南

    和其他数据库一样,MySQL也提供了命令执行sql脚本文件,方便地进行数据库、表以及数据等各种操作,这篇文章主要给大家介绍了关于MySQL执行.sql 文件的超详细教学指南,需要的朋友可以参考下
    2024-07-07

最新评论