各位用户为了找寻关于insert into … on duplicate key update / replace into 多行数据介绍的资料费劲了很多周折。这里教程网为您整理了关于insert into … on duplicate key update / replace into 多行数据介绍的相关资料,仅供查阅,以下为您介绍关于insert into … on duplicate key update / replace into 多行数据介绍的详细内容

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