mysql 使用ON DUPLICATE KEY update实现插入或更新操作

创建一个表

CREATE TABLE `userinfo` (
  `UserID` int(11) NOT NULL,
  `UserName` varchar(45) CHARACTER SET utf8 COLLATE utf8_general_ci DEFAULT NULL,
  PRIMARY KEY (`UserID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

想要实现,没有数据插入新数据,有数据更新数据

首先必须要有个唯一索引,我这里为主键UserID

然后使用ON DUPLICATE KEY update实现想要效果

insert into userinfo (UserID,UserName) VALUES  (1,"张三") ON DUPLICATE KEY update UserName="张三"

第一次没有数据,因此会插入一条新数据

insert into userinfo (UserID,UserName) VALUES  (1,"李四") ON DUPLICATE KEY update UserName="李四"

第二次因为已经有存在数据,就会将UserName更新为李四

经过测试没有问题,可用

posted @   WmW  阅读(100)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示