MySQL 5.5 INSERT ... ON DUPLICATE KEY UPDATE语句说明
发表于:2025-11-06 作者:千家信息网编辑
千家信息网最后更新 2025年11月06日,执行INSERT ... ON DUPLICATE KEY UPDATE语句,如果INSERT的语句插入的值和已有的UNIQUE索引或主键重复的话,MySQL会更新已存在的行。测试没有主键和UNIQU
千家信息网最后更新 2025年11月06日MySQL 5.5 INSERT ... ON DUPLICATE KEY UPDATE语句说明
mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2016-06-03 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
+--------+-------------+-------------+
4 rows in set (0.00 sec)
mysql> desc dept2;
+-------------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+-------+
| deptno | int(5) | NO | MUL | NULL | |
| dname | varchar(14) | YES | | NULL | |
| report_date | date | YES | MUL | NULL | |
+-------------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
mysql> INSERT INTO dept2 (deptno,dname,report_date) VALUES (20,'Development','2010-10-30')
-> ON DUPLICATE KEY UPDATE report_date='2010-10-30';
Query OK, 1 row affected (0.01 sec)
mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2016-06-03 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
| 20 | Development | 2010-10-30 |
+--------+-------------+-------------+
5 rows in set (0.00 sec)
mysql> delete from dept2 where deptno=20 and report_date=date'2010-10-30';
Query OK, 1 row affected (0.01 sec)
mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2016-06-03 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
+--------+-------------+-------------+
4 rows in set (0.00 sec)
增加主键,再进行测试
mysql> alter table dept2 add primary key(deptno);
Query OK, 0 rows affected (0.28 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> INSERT INTO dept2 (deptno,dname,report_date) VALUES (20,'Development','2010-10-30')
-> ON DUPLICATE KEY UPDATE report_date='2010-10-30';
Query OK, 2 rows affected (0.14 sec)
mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2010-10-30 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
+--------+-------------+-------------+
4 rows in set (0.00 sec)
执行INSERT ... ON DUPLICATE KEY UPDATE语句,如果INSERT的语句插入的值和已有的UNIQUE索引或主键重复的话,MySQL会更新已存在的行。
测试没有主键和UNIQUE索引的表mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2016-06-03 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
+--------+-------------+-------------+
4 rows in set (0.00 sec)
mysql> desc dept2;
+-------------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+-------+
| deptno | int(5) | NO | MUL | NULL | |
| dname | varchar(14) | YES | | NULL | |
| report_date | date | YES | MUL | NULL | |
+-------------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
mysql> INSERT INTO dept2 (deptno,dname,report_date) VALUES (20,'Development','2010-10-30')
-> ON DUPLICATE KEY UPDATE report_date='2010-10-30';
Query OK, 1 row affected (0.01 sec)
mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2016-06-03 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
| 20 | Development | 2010-10-30 |
+--------+-------------+-------------+
5 rows in set (0.00 sec)
mysql> delete from dept2 where deptno=20 and report_date=date'2010-10-30';
Query OK, 1 row affected (0.01 sec)
mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2016-06-03 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
+--------+-------------+-------------+
4 rows in set (0.00 sec)
增加主键,再进行测试
mysql> alter table dept2 add primary key(deptno);
Query OK, 0 rows affected (0.28 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> INSERT INTO dept2 (deptno,dname,report_date) VALUES (20,'Development','2010-10-30')
-> ON DUPLICATE KEY UPDATE report_date='2010-10-30';
Query OK, 2 rows affected (0.14 sec)
mysql> select * from dept2;
+--------+-------------+-------------+
| deptno | dname | report_date |
+--------+-------------+-------------+
| 10 | Research | 2016-06-03 |
| 20 | Maintenance | 2010-10-30 |
| 30 | Leader | 2016-06-03 |
| 40 | Market | 2015-08-02 |
+--------+-------------+-------------+
4 rows in set (0.00 sec)
语句
索引
测试
更新
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
tsv 数据库
西安国产化服务器生产厂商
平定公安局网络安全电话
怎么画网络安全主题手抄报
软件开发工程师mis
服务器稳定性 安全性
提高防范意识维护网络安全
网络技术计算机四级考试题型
粘土服务器噬梦箱在哪开
阳光纳什网络技术有限公司
方舟端游服务器怎么开麦
涪陵区网络安全审计系统咨询公司
媒体服务器是不是就是解码器
imap服务器怎么开启
数据库为0
徐汇区创新数据库服务销售价格
计算机网络安全的学法
梦幻西游手游歌尽桃花服务器下载
网络安全7种意识
飞思卡尔芯片软件开发环境
下列属于数据库物理设计的是
盐田区网络技术转移服务费
崂山数据库开发招聘信息
中国国家学术调查数据库
如何做才能将网络安全做好
软件开发在西安的市场需求
卡通时钟软件开发
公众号第三方开发需要多大服务器
图书馆怎样提高数据库使用培训
苹果软件开发者版本