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行 (先删除,再新增)
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
解决Win7 x64安装解压版mysql 5.7.18 winx64出现服务无法启动问题
这篇文章主要介绍了解决Win7 x64安装解压版mysql 5.7.18 winx64出现服务无法启动问题,需要的朋友可以参考下2017-05-05
MySQL Index Condition Pushdown(ICP)性能优化方法实例
这篇文章主要介绍了MySQL Index Condition Pushdown(ICP)性能优化方法实例,本文讲解了概念介绍、原理、实践案例、案例分析、ICP的使用限制等内容,需要的朋友可以参考下2015-05-05
MySQL Community Server压缩包安装配置方法
这篇文章主要为大家详细介绍了MySQL Community Server压缩包安装配置方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-11-11


最新评论