mysql重复插入数据教程(Mysql避免重复插入数据的4种方式)
mysql重复插入数据教程
Mysql避免重复插入数据的4种方式最常见的方式就是为字段设置主键或唯一索引,当插入重复数据时,抛出错误,程序终止,但这会给后续处理带来麻烦,因此需要对插入语句做特殊处理,尽量避开或忽略异常,下面我简单介绍一下,感兴趣的朋友可以尝试一下:
这里为了方便演示,我新建了一个user测试表,主要有id,username,sex,address这4个字段,其中主键为id(自增),同时对username字段设置了唯一索引:
01 insert ignore into
即插入数据时,如果数据存在,则忽略此次插入,前提条件是插入的数据字段设置了主键或唯一索引,测试SQL语句如下,当插入本条数据时,MySQL数据库会首先检索已有数据(也就是idx_username索引),如果存在,则忽略本次插入,如果不存在,则正常插入数据:
02 on duplicate key update
即插入数据时,如果数据存在,则执行更新操作,前提条件同上,也是插入的数据字段设置了主键或唯一索引,测试SQL语句如下,当插入本条记录时,MySQL数据库会首先检索已有数据(idx_username索引),如果存在,则执行update更新操作,如果不存在,则直接插入:
03 replace into
即插入数据时,如果数据存在,则删除再插入,前提条件同上,插入的数据字段需要设置主键或唯一索引,测试SQL语句如下,当插入本条记录时,MySQL数据库会首先检索已有数据(idx_username索引),如果存在,则先删除旧数据,然后再插入,如果不存在,则直接插入:
04 insert if not exists
即insert into … select … where not exist ... ,这种方式适合于插入的数据字段没有设置主键或唯一索引,当插入一条数据时,首先判断MySQL数据库中是否存在这条数据,如果不存在,则正常插入,如果存在,则忽略:
目前,就分享这4种MySQL处理重复数据的方式吧,前3种方式适合字段设置了主键或唯一索引,最后一种方式则没有此限制,只要你熟悉一下使用过程,很快就能掌握的,网上也有相关资料和教程,介绍的非常详细,感兴趣的话,可以搜一下
到此这篇关于Mysql避免重复插入数据的4种方式的文章就介绍到这了,更多相关Mysql避免重复插入数据内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
原文链接:https://juejin.cn/post/6923558675277676558
- mysql查询语法总结(MySQL全面瓦解之查询的过滤条件详解)
- mysql数据库三种模式(MySQL数据库是如何实现XA规范的)
- mysql主从复制原理详解(详解MySQL kill 指令的执行原理)
- mysql中常用的三种存储引擎的区别(MySQL 存储过程的优缺点分析)
- mysql 排序源码(MySQL排序原理和案例详析)
- mysql常用数据模型(MySQL数据库基于sysbench实现OLTP基准测试)
- mysql常用的sql语句大全(mysql建表常用的sql语句汇总)
- mysql中行列转换(mysql 行列转换的示例代码)
- mysql连接查询原理(MySQL连接查询你真的学会了吗?)
- mysql操作时间的函数(一篇文章搞定Mysql日期时间函数)
- 适合小白入门的mysql教程索引简介(一篇带给你MySQL高性能索引)
- mysql字符类型长度限制
- mysql order by id查询变慢(MySQL不使用order by实现排名的三种思路总结)
- zabbix监控sql server集群(zabbix 监控mysql的方法)
- 织梦源码安装数据库怎么填(Mysql修改端口号 织梦DedeCMS设置教程)
- 如何找到mysqlroot密码(WDCP管理面板忘记MYSQL ROOT密码及重置后台登录密码的方法汇总)
- NVIDIA显卡份额冲上88 A饭发愁 游戏优化恐没A卡份了(NVIDIA显卡份额冲上88A饭发愁)
- AMD YES A卡还是N卡 A卡和N卡的区别(AMDYESA卡还是N卡)
- 以后显卡多了一个新选择,N卡和A卡外又多了个I卡(以后显卡多了一个新选择)
- 读卖乐园的彩灯(读卖乐园的彩灯)
- 新疆80后在淘宝卖干果 以前是 不务正业 如今帮乡亲致富(新疆80后在淘宝卖干果)
- 弄清楚了销 售 买 卖这四个字,母婴生意做起来就没那么难了(弄清楚了销售买)
热门推荐
- 关于docker安全之Docker-TLS加密通讯问题(关于docker安全之Docker-TLS加密通讯问题)
- ubuntu开通端口(ubuntu开启22端口的实现)
- ASP.NET根据IP获取省市地址
- vue中的ref(Vue3.0中Ref与Reactive的区别示例详析)
- mysql8.0.12安装教程图解(mysql 8.0.22 zip压缩包版免安装下载、安装配置步骤详解)
- 查看docker容器进程运行状态命令(docker容器内要启动两个进程时Dockerfile的实现代码)
- js event对象
- python 摄像头运用(使用Python控制摄像头拍照并发邮件)
- docker容器启动执行脚本(在docker容器中使用非root用户执行脚本操作)
- dedecms幻灯片代码(dedecms实现大图showphoto.htm输出图集内容简介方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9