insert into … on duplicate key update / replace into 多行数据介绍
程序员文章站
2024-02-23 20:01:58
场景是这样的,我有kv型的表,建表语句如下:
复制代码 代码如下:create table `dkv` ( `k1` int(11) not null de...
场景是这样的,我有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 |
+----+----+-----------+
上一篇: c#在excel中添加超链接示例分享
推荐阅读
-
insert into … on duplicate key update / replace into 多行数据介绍
-
mysql 中 replace into 与 insert into on duplicate key update 的用法和不同点实例分析
-
insert into … on duplicate key update / replace into 多行数_MySQL
-
MYSQL的REPLACE和ON DUPLICATE KEY UPDATE语句介绍解决问题实例_MySQL
-
MySQL的Replace into与Insert into...on duplicate key update.._MySQL
-
MySQL的Replace into 与Insert into on duplicate key update真_MySQL
-
insert into … on duplicate key update / replace into 多行数_MySQL
-
MYSQL的REPLACE和ON DUPLICATE KEY UPDATE语句介绍解决问题实例_MySQL
-
MySQL的Replace into 与Insert into on duplicate key update真_MySQL
-
mysql 中 replace into 与 insert into on duplicate key update 的用法和不同点实例分析