insertinto…onduplicatekeyupdate/replaceinto多行数据介绍
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了insertinto…onduplicatekeyupdate/replaceinto多行数据介绍,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1861字,纯文字阅读大概需要3分钟。
内容图文
![insertinto…onduplicatekeyupdate/replaceinto多行数据介绍](/upload/InfoBanner/zyjiaocheng/585/33b9d121aaec4d5c913251cec8a89219.jpg)
场景是这样的,我有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 |
+----+----+-----------+
您可能感兴趣的文章:
- INSERT INTO .. ON DUPLICATE KEY更新多行记录
- 深入mysql "ON DUPLICATE KEY UPDATE" 语法的分析
- Mysql中Insert into xxx on duplicate key update问题
- mysql #1062 –Duplicate entry ''1'' for key ''PRIMARY''
- mysql error:#1062 Duplicate entry ‘***′ for key 1问题解决方法
- mysql insert的几点操作(DELAYED,IGNORE,ON DUPLICATE KEY UPDATE )
内容总结
以上是互联网集市为您收集整理的insertinto…onduplicatekeyupdate/replaceinto多行数据介绍全部内容,希望文章能够帮你解决insertinto…onduplicatekeyupdate/replaceinto多行数据介绍所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。