mysql插入重复数据的处理(DUPLICATE、IGNORE、REPLACE)

 更新时间:2023年09月05日 10:00:21   作者:牟云飞  
这篇文章主要介绍了mysql插入重复数据的处理方式(DUPLICATE、IGNORE、REPLACE),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql插入重复数据的三种处理方式

1、插入或者更新  DUPLICATE

“INSERT   ...  ON  DUPLICATE   KEY  UPDATE   ”,

它是在插入操作时,如果数据出现重复,则更新重复数据的值。 

示例:

INSERT INTO myf_deal_data ( `ID`, `PTNAME`, `PTDATA`, `OPERTIME`, `REPORTTIME` )
VALUES
    ( 111, '858_Ua', '219.1000', '2022-04-01 00:45:00', '2022-06-28 10:04:52' ) 
ON DUPLICATE KEY UPDATE PTDATA = '219.9000',REPORTTIME = NOW()

示例解释:

这条语句意味着,如果myf_deal_data表,存在id为111的数据,那么就将更新PTDATA 和REPORTTIME 的值

需要权限:insert、update

影响行数:2行

注意:多线程并发会导致死锁的可能。

2、插入或者丢弃  IGNORE  

“  INSERT  IGNORE  INTO ..  VALUES   ”的用法

是在插入操作时,如果数据出现重复,则忽略这个操作,不会报错,但也不会插入重复的数据。

示例:

INSERT IGNORE INTO myf_deal_data ( `ID`, `PTNAME`, `PTDATA`, `OPERTIME`, `REPORTTIME` )
VALUES
    ( 111, '858_Ua', '219.1000', '2022-04-01 00:45:00', '2022-06-28 10:04:52' ) 

示例解释:

向myf_deal_data 表插入数据,如果myf_deal_data 表的主键字段( ID 字段)已经存在 111这个值,那么这条语句就会被忽略,不会插入数据,也不会报错。

需要权限:insert

影响行数:0行

3、插入或者替换  REPLACE 

“  REPLACE INTO ...  VALUES   ”的用法

是在插入操作时,如果不存在插入数据,如果数据出现重复,则更新数据(与DUPLICATE不同,需要的是insert、delete权限,是先删除后新增)。

示例:

REPLACE INTO  myf_deal_data ( `ID`, `PTNAME`, `PTDATA`, `OPERTIME`, `REPORTTIME` )
VALUES
    ( 58261907, '858_Ua', '219.1000', '2022-04-01 00:45:00', '2022-06-28 10:04:52' ) 

示例解释:

向myf_deal_data 表插入数据,如果myf_deal_data 表的主键字段( ID 字段)已经存在 111这个值,那么这条语句就会被忽略,不会插入数据,也不会报错。

需要权限:insert、delete

影响行数:2行   (先删除,再新增)

总结

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

相关文章

  • SQL实现LeetCode(176.第二高薪水)

    SQL实现LeetCode(176.第二高薪水)

    这篇文章主要介绍了SQL实现LeetCode(176.第二高薪水),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • mysql子查询(单行子查询,多行子查询,多列子查询)

    mysql子查询(单行子查询,多行子查询,多列子查询)

    本文主要介绍了mysql子查询(单行子查询,多行子查询,多列子查询),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • mysql 编码设置命令

    mysql 编码设置命令

    mysql 编码设置命令,需要的朋友可以参考下。
    2009-10-10
  • MySQL 8.0 新特性之检查约束的实现

    MySQL 8.0 新特性之检查约束的实现

    这篇文章主要介绍了MySQL 8.0 新特性之检查约束的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 浅谈sql数据库去重

    浅谈sql数据库去重

    关于sql去重,我简单谈一下自己的理解和经验,如果各位有建议或有不明白的欢迎多多指出。
    2014-08-08
  • MySQL千万级数据的大表优化解决方案

    MySQL千万级数据的大表优化解决方案

    mysql数据库中的表数据量几千万后,查询速度会很慢,日常各种卡慢,严重影响使用体验。在考虑升级数据库或者换用大数据解决方案前,必须优化现有mysql数据库表设计和sql语句。
    2022-11-11
  • MySQL MyISAM 与InnoDB 的区别

    MySQL MyISAM 与InnoDB 的区别

    这篇文章主要介绍了MySQL MyISAM与InnoDB 的区别,帮助大家更好的理解和使用MySQL的存储引擎,感兴趣的朋友可以了解下
    2020-09-09
  • Linux下mysql 5.7 部署及远程访问配置

    Linux下mysql 5.7 部署及远程访问配置

    这篇文章主要为大家详细介绍了Linux下mysql 5.7 部署及远程访问的配置方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-09-09
  • mysql 5.7 的 /etc/my.cnf 参数介绍

    mysql 5.7 的 /etc/my.cnf 参数介绍

    这篇文章主要介绍了mysql 5.7 的 /etc/my.cnf 参数介绍,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • MySQL高级操作指令汇总

    MySQL高级操作指令汇总

    本文给大家带来的是MySQL高级操作指令代码,罗列的很详细并且附带有例子,对大家的学习将会很有用,建议收藏以防丢失,需要的朋友可以参考下
    2022-01-01

最新评论