广告
返回顶部
首页 > 资讯 > 数据库 >详解MySql如何不插入重复数据
  • 812
分享到

详解MySql如何不插入重复数据

MySql不插入重复数据MySql重复数据 2023-01-17 10:01:34 812人浏览 八月长安
摘要

目录1、insert ignore into2、on duplicate key update3、insert ... select ... where not exist4、replace into

数据库的插入值时,需要判断插入是否重复,然后插入。

这种操作怎么提高效率

下面说说一些解决方案

1、insert ignore into

当插入数据时,如出现错误时,如重复数据,将不返回错误,只以警告形式返回。所以使用ignore请确保语句本身没有问题,否则也会被忽略掉。例如:

INSERT IGNORE INTO USER ( NAME )
VALUES ( '张三' );

这种方法很简单,但是有一种可能插入不是因为重复数据报错,而是因为其他原因报错的,也同样被忽略了~

2、on duplicate key update

当primary 或者 unique重复时,则执行update语句;
当update后为无用语句,如:id=id,错误不会被忽略。

INSERT INTO USER ( NAME )
VALUES ( '张三' ) 
ON DUPLICATE KEY UPDATE id = id;

这种方法有个前提条件,就是需要约束条件,即,主键或者唯一约束。

3、insert ... select ... where not exist

根据select的条件判断是否插入

INSERT INTO USER ( NAME ) 
SELECT '张三' FROM DUAL 
WHERE NOT EXISTS (SELECT id FROM USER WHERE id = 1)

这种方法其实就是使用Mysql的一个临时表的方式,但是里面使用子查询,效率会有影响,能不使用尽量避免。

4、replace into

如果存在 primary 或者 unique 相同的记录,则先删除再插入新记录。

REPLACE INTO USER SELECT 1, '张三' FROM USER

这种方法就是不管原来有没有相同的记录,都会先删除再插入。

到此这篇关于详解mysql如何不插入重复数据的文章就介绍到这了,更多相关Mysql不插入重复数据内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: 详解MySql如何不插入重复数据

本文链接: https://www.lsjlt.com/news/177947.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作