• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql中插入记录时不存在时插入已经存在则更新

mysql 搞代码 4年前 (2022-01-09) 35次浏览 已收录 0个评论

有很多朋友都在问关于mysql中插入记录时不存在时插入已经存在则更新这个问题怎么操作,下面我来介绍介绍。ON DUPLICATE KEY UPDATE的使用

如果您指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执

行旧行UPDATE。例如,如果列a被定义为UNIQUE,并且包含值1,则以下两个语句具有相同的效果:

代码如下:

代码如下复制代码

mysql> INSERT INTO table (a,b,c) VALUES (1,2,3)
-> ON DUPLICATE KEY UPDATE c=c+1;
mysql> UPDATE table SET c=c+1 WHERE a=1;

实例1

代码如下复制代码

mysql> truncate `200702`;
Query OK, 0 rows affected (0.01 sec)

mysql> select * from `200702`;
Empty set (0.01 sec)

mysql> insert into `200702` (`domain`, `2nd_domain`, `tld`, `query_ns1`, `query_ns2`, `report_date`)

values (‘dnspod.com’, ‘dnspod’, ‘com’, 1000, 2000, ‘2007-02-04’) ON DUPLICATE KEY UPDATE `query_ns1` =

`query_ns1` + 1000, `query_ns2` = `query_ns2` + 2000;
Query OK, 1 row affected (0.00 sec)

mysql> select * from `200702`;
+—-+————+————+——+———–+———–+———–+———–+————-+
| id | domain | 2nd_domain | tld | query_ns1 | query_ns2 | query_ns3 | query_ns4 | report_date |
+—-+————+————+——+———–+———–+———–+———–+————-+
| 1 | dnspod.com | dnspod | com | 1000 | 2000 | 0 | 0 | 2007-02-04 |
+—-+————+————+——+———–+———–+———–+———–+————-+
1 row in set (0.00 sec)

mysql> insert into `200702` (`domain`, `2nd_domain`, `tld`, `query_ns1`, `query_ns2`, `report_date`)

values (‘dnspod.com’, ‘dnspod’, ‘com’, 1000, 2000, ‘2007-02-04’) ON DUPLICATE KEY UPDATE `query_ns1` =

`query_ns1` + 1000, `query_ns2` = `query_ns2` + 2000;
Query OK, 2 rows affected (0.01 sec)

mysql> select * from `200702`;
+—-+————+————+——+———–+———–+———–+———–+————-+
| id | domain | 2nd_domain | tld | query_ns1 | query_ns2 | query_ns3 | query_ns4 | report_date |
+—-+————+————+——+———–+———–+———–+———–+————-+
| 1 | dnspod.com | dnspod | com | 2000 | 4000 | 0 | 0 | 2007-02-04 |
+—-+————+————+——+———–+———–+———–+———–+————-+
1 row in set (0.01 sec)

mysql>

当然,建表的时候,千万别忘记了给domain做一个unique

代码如下复制代码

UNIQUE KEY `domain` (`domain`,`report_date`)

key存在则更新,不存在则插入

代码如下复制代码

insert into …. on duplicate key update

对于需要根据原记录进行操作的.如表中icount字段用于计数,当没有记录时,插入的value为0,当有记录时,value需要

更新为value+1,这时replace就不能完成这个功能.使用insert则可以,其基本语法是insert into … on duplicate

key update…,如上述语句为

代码如下复制代码

insert into t_test set ikey=1,value=’a’,value2=1 on duplicate key update value2=value2+1;

如果表中有多个唯一索引,如对value字段加个unique key.这时表中有ikey和value两个唯一索引,replace会把所有与

其唯一索引值相同的数据项删除,再插入新记录.如表中有两个记录

代码如下复制代码

+——+——-+——–+
| ikey | value | icount |
+——+——-+——–+
| 2 | a | 10 |
| 1 | b | 40 |
+——+——-+——–+

则replace into t_test set ikey=1,value=’a’,icount=0;会把表中的两条记录都删除,然后插入新记录.
而insert into t_test set ikey=1,value=’a’,icount=0 on duplicate key update icount=icount+1则只更新一条

记录.其效果相当于

代码如下复制代码
update t_test set icount=icount+1 where ikey=1 or value=’a’ li

本文来源gaodai^.ma#com搞#代!码网

mit 1;


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql中插入记录时不存在时插入已经存在则更新

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址