帮助中心/最新通知

质量为本、客户为根、勇于拼搏、务实创新

< 返回文章列表

【服务器相关】SQL开发知识:Mysql如何实现不存在则插入,存在则更新,replace讲解

发表时间:2025-06-16 03:46:00 小编:主机乐-Yutio

数据准备

ON DUPLICATE KEY UPDATE

REPLACE INTO … VALUES…

无论是insert on duplicate key update还是replace into,在插入时MySQL返回的影响行数就是插入的记录数,但是在更新时返回的影响行数是更新行数*2。

INSERT IGNORE INTO … VALUES…


INSERT IGNORE INTO test_table(id,username) 
values(6,’fukaiit’);

执行如上sql,该id不存在,相当于执行了insert,普通插入,受影响的行:1。


INSERT IGNORE INTO test_table(id,username) 
values(1,’fukaiit_new’);

执行如上sql,该id已存在,忽略了该插入操作,数据没有变化,受影响的行:0。

使用DUAL虚表和NOT EXISTS

该方法与INSERT IGNORE INTO … VALUES…方法的效果相同。


INSERT INTO test_table(id,username)
SELECT 7,’fukaiit’ from DUAL 
where NOT EXISTS (select * from test_table where id=7);

执行如上sql,该id不存在,select子句返回结果集为空,NOT EXISTS成立,相当于执行了insert,普通插入,受影响的行:1。


INSERT INTO test_table(id,username)
SELECT 2,’fukaiit’ from DUAL 
where NOT EXISTS (select * from test_table where id=2);

执行如上sql,该id已存在,select子句返回结果集不为空,NOT EXISTS不成立,则未执行插入操作,数据没有变化,受影响的行:0。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。


联系我们
返回顶部