≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > MySQL

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

人气:464 时间:2020-07-09

这篇文章主要为大家详细介绍了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  | 
+----+----+-----------+

 

本文来自:http://www.q1010.com/177/9721-0.html

注:关于insert into … on duplicate key update / replace into 多行数据介绍的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:MYSQL

您可能感兴趣的文章

  • MySQL 关键词相关度排序方法详细示例分析
  • INSERT INTO .. ON DUPLICATE KEY更新多行记录
  • MySQL获取系统性能和状态代码
  • MySQL修改所有表的存储引擎格式语句
  • MySQL——修改root密码的4种方法(以windows为例)
  • MySQL 导入导出数据库以及函数、存储过程的介绍
  • MySQL无法启动几种常见问题小结
  • 如何开启MySQL中的严格模式
  • MySQL在debian系统中不能插入中文的终极解决方案
  • MySQL中的load命令使用方法
上一篇:MySQL中order by与group by的区别
下一篇:MySQL 关键词相关度排序方法详细示例分析
热门文章
  • mysql 修改character_set_server为utf-8的简单示例
  • 解决MySQL丢失文件localhost.localdomain.pid、mysql.sock的示例
  • MySQL 数据类型binary和varbinary的简单示例
  • MySQL:reading initial communication packet问题解决方法
  • MySql 表类型MYISAM、InnoDB区别
  • bash: mysql: command not found 的解决方法
  • MYSQL默认用户名ROOT修改方法
  • MySQL 常用命令菜鸟教程
  • MySQL 使用命令行新建用户并授予权限
  • MySql 数据库物理文件存放位置查看示例
  • 最新文章
    • MySQL查看死锁与解除死锁的简单示例
    • MySQL 慢查询的功能实例
    • MySQL查看死锁与去除死锁的简单示例
    • MySQL找出未提交事务的SQL的简单示例
    • MySQL锁阻塞的的简单示例
    • MySQL中的binary类型使用操作的示例
    • SQL优化教程之in与range查询的简单示例
    • MySQL 的 21 个规范、优化最佳实践!
    • MySQL 字符类型大小写敏感的简单示例
    • 解决mybatis-plus分页传入参数后sql where条件没有limit分页信息的问题

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。