源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2021-12-30 17:18 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:insert into … on duplicate key update / replace into 多行数据介绍
场景是这样的,我有KV型的表,建表语句如下:
[u]复制代码[/u] 代码如下:
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
[u]复制代码[/u] 代码如下:
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:
[u]复制代码[/u] 代码如下:
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');
最终都能将数据改成这样:
[u]复制代码[/u] 代码如下:
+----+----+-----------+ | 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  | +----+----+-----------+
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部