实践 | 在MySql中,这四种方法可以避免重复插入数据!
前言
MySql 在存在主键冲突或唯一键冲突的情况下,根据插入方式,一般有以下四种插入方式避免错误。
insert ignore。
replace into
insert on duplicate key update
insert ignore
insert ignore 会忽视数据库中已经存在的数据,根据主键或者唯一索引判断,如果数据库没有数据,就会插入新的数据,如果有数据的话就跳过这条数据
小case
表结构
root:test> show create table t3G
*************************** 1. row ***************************Table: t3
Create Table: CREATE TABLE `t3` (`id` int(11) NOT NULL AUTO_INCREMENT,`c1` int(11) DEFAULT NULL,`c2` varchar(20) DEFAULT NULL,`c3` int(11) DEFAULT NULL,PRIMARY KEY (`id`),UNIQUE KEY `uidx_c1` (`c1`)
) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)root:test> select * from t3;+----+------+------+------+| id | c1 | c2 | c3 |+----+------+------+------+| 1 | 1 | a | 1 || 2 | 2 | a | 1 || 8 | NULL | NULL | 1 || 14 | 4 | bb | NULL || 17 | 5 | cc | 4 |+----+------+------+------+5 rows in set (0.00 sec)
插入冲突数据
root:test> insert ignore into t3 (c1,c2,c3) values(5,'cc',4),(6,'dd',5); Query OK, 1 row affected, 1 warning (0.01 sec)
Records: 2 Duplicates: 1 Warnings: 1
查看结果
root:test> show warnings;
+---------+------+---------------------------------------+
| Level | Code | Message |
+---------+------+---------------------------------------+
| Warning | 1062 | Duplicate entry '5' for key 'uidx_c1' |
+---------+------+---------------------------------------+
1 row in set (0.00 sec)root:test> select * from t3;
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | a | 1 |
| 2 | 2 | a | 1 |
| 8 | NULL | NULL | 1 |
| 14 | 4 | bb | NULL |
| 17 | 5 | cc | 4 |
| 18 | 6 | dd | 5 |
+----+------+------+------+
6 rows in set (0.00 sec)
replace into
replace into 会尝试先插入数据,如果发现冲突进行删除。否则不做任何操作。
小case
root:test> show create table t3G
*************************** 1. row ***************************Table: t3
Create Table: CREATE TABLE `t3` (`id` int(11) NOT NULL AUTO_INCREMENT,`c1` int(11) DEFAULT NULL,`c2` varchar(20) DEFAULT NULL,`c3` int(11) DEFAULT NULL,PRIMARY KEY (`id`),UNIQUE KEY `uidx_c1` (`c1`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)root:test> select * from t3;
+----+------+--------+------+
| id | c1 | c2 | c3 |
+----+------+--------+------+
| 1 | 1 | cc | 4 |
| 2 | 2 | dd | 5 |
| 3 | 3 | qwewqe | 3 |
+----+------+--------+------+
3 rows in set (0.00 sec)
插入冲突数据
root:test> replace into t3 (c1,c2,c3) values(3,'new',8);
Query OK, 2 rows affected (0.02 sec)root:test> select * from t3;
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | cc | 4 |
| 2 | 2 | dd | 5 |
| 4 | 3 | new | 8 |
+----+------+------+------+
3 rows in set (0.00 sec)
可以看到原有的记录已经没有了,新的记录又有了。
insert on duplicate key update
如果在insert into 语句末尾指定了 insert on duplicate key update 如果出现了重复值,则会在出现重复值以后进行update。
case
root:test> show create table t3G
*************************** 1. row ***************************Table: t3
Create Table: CREATE TABLE `t3` (`id` int(11) NOT NULL AUTO_INCREMENT,`c1` int(11) DEFAULT NULL,`c2` varchar(20) DEFAULT NULL,`c3` int(11) DEFAULT NULL,PRIMARY KEY (`id`),UNIQUE KEY `uidx_c1` (`c1`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)root:test> select * from t3;
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | fds | 4 |
| 2 | 2 | ytu | 3 |
| 3 | 3 | czx | 5 |
+----+------+------+------+
3 rows in set (0.00 sec)
插入一条与记录id=3存在唯一键(列c1)冲突的数据
root:test> insert into t3(c1,c2,c3) values (3,'new',5) on duplicate key update c1=c1+3;
Query OK, 2 rows affected (0.01 sec)root:test> select * from t3;
+----+------+------+------+
| id | c1 | c2 | c3 |
+----+------+------+------+
| 1 | 1 | fds | 4 |
| 2 | 2 | ytu | 3 |
| 3 | 6 | czx | 5 |
+----+------+------+------+
3 rows in set (0.00 sec)
可以看到,id=3的记录发生了改变,c1=原有的c1+3,其他列没有改变。
小明菜市场
推荐阅读
● 理论 | 分库分表需要考虑的问题及方案
● 理论 | 六种延迟队列的实现方案
● 实战 | Element UI 父子组件传值与事件绑定(逆向)
● 实战 | Element UI 父子组件传值与事件绑定(正向)
● 实战 | Vue + Element UI 表格组件二次封装
实践 | 在MySql中,这四种方法可以避免重复插入数据!相关推荐
- 在MySql中,这四种方法可以避免重复插入数据!
前言 MySql 在存在主键冲突或唯一键冲突的情况下,根据插入方式,一般有以下四种插入方式避免错误. insert ignore. replace into insert on duplicate k ...
- 查看mysql版本的四种方法
2019独角兽企业重金招聘Python工程师标准>>> 查看mysql版本的四种方法 1:在终端下:mysql -V. 以下是代码片段: [shengting@login ~]$ m ...
- linux下查看mysql版本的四种方法
Linux查看MySQL版本的四种方法 1 在终端下执行 mysql -V 2 在help中查找 mysql --help |grep Distrib 3 在mysql 里查看 select vers ...
- mysql中的四种注释
mysql中的四种注释 NO1:-- 注释内容 这种注释方法不能够实现多行注释,要注意的是 --后面是有一个空格的.(-- 后面的内容将不会被识别,因此需要在下一行加上分号来结束该语句) NO2:#注 ...
- 查看mysql数据库版本_MySQL数据库之查看MySQL版本的四种方法
本文主要向大家介绍了MySQL数据库之查看MySQL版本的四种方法 ,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助. 1.终端下直接使用mysql命令 [root@localhos ...
- 批量 杀掉 mysql 连接_批量杀死MySQL连接的四种方法详解
方法一 通过information_schema.processlist表中的连接信息生成需要处理掉的MySQL连接的语句临时文件,然后执行临时文件中生成的指令.复制代码 代码如下:mysql> ...
- 阿里云查看mysql版本_查看mysql版本的四种方法及常用命令
[shengting@login ~]$ mysql -V mysql Ver 14.7 Distrib 4.1.10a, for redhat-linux-gnu (i686) 2:在mysql中: ...
- 如何看mysql版本_如何查看mysql版本的四种方法,MySQL版本查看
1:在终端下:mysql -V. 以下是代码片段: [shengting@login ~]$ mysql -V mysql Ver 14.7 Distrib 4.1.10a, for redhat-l ...
- Linux 查看 MySQL 版本的四种方法
1 在终端下执行 mysql -V 2 在help中查找 mysql --help |grep Distrib 3 在mysql 里查看 select version() 4 在mysql 里查看 s ...
最新文章
- linux输入文件后怎么保存不了怎么办,关于linux:输入数据后为什么不能保存VI文件?...
- 在js中获取input中的value
- SAP方丈-写给新手的SAP成本核算流程
- 九、“行胜于言车胜马,负重致远向前途”
- Caliburn笔记-Action简写(wpf框架)
- CodeForces - 1335E2 Three Blocks Palindrome (hard version)(思维)
- io_uring vs epoll ,谁在网络编程领域更胜一筹?
- 解决MySQL 8.0 设置简单密码报错ERROR 1819 (HY000): Your password does not satisfy the current policy require...
- 选择适合自己的 OLAP 引擎,干货
- mysql s授权所有用户_批量获取mysql用户权限的方法
- 分布式链路跟踪中的traceid和spanid代表什么?
- 天气预报如何得获得?
- [导入]在vs2005中调用远程WebService(幻想曲)
- 【iOS发展-44】通过案例谈iOS重构:合并、格式化输出、宏观变量、使用数组来存储数据字典,而且使用plist最终的知识...
- 2021-06-18 链接标签
- uniapp 评论列表,展开,收起,全部,局部刷新功能
- 什么是T1 mapping?
- 分享一个有意思的游戏
- 一加 Ace Pro怎么样?颜值性能它都有
- 【Linux】查看linux是centos还是ubuntu的方法
热门文章
- 为什么300多家创新企业都在建“物联网生态系统”?
- [html] url、href、src 详解
- SpringBoot中Configure注解和Bean注解的使用
- workplace background
- HDU4907小技巧
- 算法高级(47)-AI现在都可以写代码了-辅助编程
- 思维导图系列之Java多线程知识梳理
- mysql brighthouse_mysql的三方Infobright数据仓库BRIGHTHOUSE引擎
- dubbo学习之源码创建属于自己的dubbo-demo
- android窗口动画体系,Android 7.1 GUI系统-窗口管理WMS-动画的执行(七)