当前位置: 移动技术网 > IT编程>数据库>Mysql > insert into … on duplicate key update / replace into 多行数据介绍

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

拆弹部队国语,银河护卫队2电影天堂,造梦西游3天残

场景是这样的,我有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  |
+----+----+-----------+

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网