服务器之家

服务器之家 > 正文

insert into … on duplicate key update / replace into 多行数据介绍

时间:2020-01-08 16:36     来源/作者:MYSQL教程网

场景是这样的,我有KV型的表,建表语句如下:

 

复制代码代码如下:

CREATE TABLE `dkv` ( 
  `k1` int(11) NOT NULL DEFAULT '0', 
  `k2` int(11) NOT NULL DEFAULT '0', 
  `val` varchar(30) DEFAULT NULL, 
  PRIMARY KEY (`k1`,`k2`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8

 

数据大概是这样的:

+----+----+-----------+ 
| k1 | k2 | val       | 
+----+----+-----------+ 
|  1 |  1 | value 1-1 | 
|  1 |  2 | value 1-1 | 
|  1 |  3 | value 1-1 | 
|  1 |  5 | value 1-1 | 
|  1 |  7 | value 1-1 | 
+----+----+-----------+

当我插入一条数据时,我要判断(k1,k2)是否已经存在(1条selete),若存在就update,不存在就insert,这是一个典型的merge过程,虽然按照PK执行操作的速度非常快,但是毕竟SQL交互量上去了,如果我有100笔这样的SQL,那这个开销是很可观的,有没有什么一条SQL就能搞定的事情呢?

有两种写法:

第一种: insert into … on duplicate key update

 

复制代码代码如下:

insert DELAYED into dkv  
values 
(1,2,'new 12a'), 
(1,3,'new 33ba'), 
(1,4,'new 23222'), 
(1,6,'new 12333'), 
(1,8,'new vaaaa'), 
(1,20,'new vaff'), 
(1,25,'new vaff') 
ON DUPLICATE KEY UPDATE val=VALUES(val);

 

第二种 replace into:

 

复制代码代码如下:

replace into dkv  
values 
(1,2,'new 12a'), 
(1,3,'new 33ba'), 
(1,4,'new 23222'), 
(1,6,'new 12333'), 
(1,8,'new vaaaa'), 
(1,20,'new vaff'), 
(1,25,'new vaff');

 

最终都能将数据改成这样:

 

复制代码代码如下:

+----+----+-----------+ 
| k1 | k2 | val       | 
+----+----+-----------+ 
|  1 |  1 | value 1-1 | 
|  1 |  2 | new 12a   | 
|  1 |  3 | new 33ba  | 
|  1 |  4 | new 23222 | 
|  1 |  5 | value 1-1 | 
|  1 |  6 | new 12333 | 
|  1 |  7 | value 1-1 | 
|  1 |  8 | new vaaaa | 
|  1 | 20 | new vaff  | 
|  1 | 25 | new vaff  | 
+----+----+-----------+
标签:

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
返回顶部