手机
当前位置:查字典教程网 >编程开发 >mysql数据库 >insert into … on duplicate key update / replace into 多行数据介绍
insert into … on duplicate key update / replace into 多行数据介绍
摘要:场景是这样的,我有KV型的表,建表语句如下:复制代码代码如下:CREATETABLE`dkv`(`k1`int(11)NOTNULLDEFA...

场景是这样的,我有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 update / replace into 多行数据介绍】相关文章:

MySQL数据库索引使用方法

解决hibernate+mysql写入数据库乱码

MySQL导入导出数据出现乱码的解决办法

mysql update 多表实例

MySQL编程中的6个实用技巧

SQL Server教程:三种导入导出数据使用方式比较

启动用户实例进程出错 无法生成SQL的解决方法

mysql 字符串长度计算实现代码(gb2312+utf8)

mysql 常见命令和学习心得

使用navicat 8实现创建数据库和导入数据 管理用户与权限[图文方法]

精品推荐
分类导航