广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中怎么防止重复插入数据
  • 309
分享到

MySQL中怎么防止重复插入数据

2024-04-02 19:04:59 309人浏览 八月长安
摘要

这期内容当中小编将会给大家带来有关Mysql中怎么防止重复插入数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。新建表格CREATE TABLE `p

这期内容当中小编将会给大家带来有关Mysql中怎么防止重复插入数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

新建表格

CREATE TABLE `person`  (   `id` int NOT NULL COMMENT '主键',   `name` varchar(64) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT '姓名',   `age` int NULL DEFAULT NULL COMMENT '年龄',   `address` varchar(512) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT '地址',   PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_bin ROW_FORMAT = Dynamic;

添加三条数据如下:

MySQL中怎么防止重复插入数据

我们这边可以根据插入方式进行规避:

1. insert ignore

insert ignore 会自动忽略数据库已经存在的数据(根据主键或者唯一索引判断),如果没有数据就插入数据,如果有数据就跳过插入这条数据。

插入sql如下: insert ignore into person (id,name,age,address) values(3,'那谁',23,'甘肃省'),(4,'我的天',25,'浙江省');

再次查看数据库就会发现仅插入id为4的数据,由于数据库中存在id为3的数据所以被忽略。

MySQL中怎么防止重复插入数据

2. replace into

replace into 首先尝试插入数据到表中, 1. 如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。 2.  否则,直接插入新数据。

插入SQL如下: replace into person (id,name,age,address) values(3,'那谁',23,'甘肃省'),(4,'我的天',25,'浙江省');

首先我们将表中数据恢复,然后进行插入操作后发现id为3的数据发生了改变同时新增了id为4的数据。

MySQL中怎么防止重复插入数据

3. insert on duplicate key update

insert on duplicate key update 如果在insert into语句的末尾指定了on duplicate key update  + 字段更新,则会在出现重复数据(根据主键或者唯一索引判断)的时候按照后面字段更新的描述对该信息进行更新操作。

插入SQL如下: insert into person (id,name,age,address) values(3,'那谁',23,'甘肃省') on duplicate key update name='那谁', age=23, address='甘肃省';

首先我们将表中数据恢复,然后在进行插入操作时,发现id为3的数据发生了改变,进行了更新操作。

MySQL中怎么防止重复插入数据

上述就是小编为大家分享的mysql中怎么防止重复插入数据了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中怎么防止重复插入数据

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

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

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

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

下载Word文档
猜你喜欢
  • MySQL中怎么防止重复插入数据
    这期内容当中小编将会给大家带来有关MySQL中怎么防止重复插入数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。新建表格CREATE TABLE `p...
    99+
    2022-10-18
  • SQLServer中怎么防止并发插入重复数据
    SQLServer中怎么防止并发插入重复数据,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。SQLServer中防止并发插入重复...
    99+
    2022-10-18
  • Mysql 唯一索引 防止重复插入数据
    一般的批量插的 sql语句数据违反唯一性约束时,出现重复数据将会直接报错并停止执行 insert into tb_name (field1,field2) values(f11,f12),(f21,f22)... 这种语句将会报错并停止...
    99+
    2020-05-18
    Mysql 唯一索引 防止重复插入数据 数据库入门 数据库基础教程 数据库 mysql
  • 防止MySQL重复插入数据的三种方法
    新建表格 CREATE TABLE `person` ( `id` int NOT NULL COMMENT '主键', `name` varchar(64) CHARACTER SET utf8 ...
    99+
    2022-05-19
    MySQL 重复插入数据 MySQL 防止重复插入数据
  • MySQL中怎么防止数据重复
    MySQL中怎么防止数据重复,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。很多时候在日常的项目中,有些数据是不允许重复的,例如用户信息中的登陆...
    99+
    2022-10-18
  • MySQL中怎么插入不重复数据
    这期内容当中小编将会给大家带来有关MySQL中怎么插入不重复数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。   之前最naive的想法就是先对将要插入的...
    99+
    2022-10-18
  • MySQL中怎么不插入重复数据
    这期内容当中小编将会给大家带来有关MySQL中怎么不插入重复数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1、insert ignore into当插入数据时,如出现...
    99+
    2022-10-18
  • 如何生成HASH索引防止数据重复插入
    如何生成HASH索引防止数据重复插入,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。任何数据库都有唯一值,唯一索引这个概念,起到的作用是防止重复的值插入到数据库中已经设置的唯一索...
    99+
    2023-06-19
  • mysql并发防止重复数据怎么实现
    在MySQL中,可以通过以下几种方式来实现并发操作时防止重复数据的问题: 使用UNIQUE约束:在创建表时,可以在某个列上添加U...
    99+
    2023-10-23
    mysql
  • java怎么防止重复请求数据
    有以下几种方法可以防止重复请求数据: 前端防重复提交:前端可以通过禁用提交按钮或者添加遮罩层等方式,在接收到请求后禁止用户再次提...
    99+
    2023-10-25
    java
  • MySql批量插入时如何不重复插入数据
    目录前言一、insert ignore into二、on duplicate key update三、replace into总结前言 Mysql插入不重复的数据,当大数据量的数据需...
    99+
    2022-11-12
  • java防止重复数据请求怎么实现
    有多种方法可以实现防止重复数据请求的功能,以下是其中一种常见的做法: 在Java应用中定义一个全局的缓存对象,用于存储已经处理过的...
    99+
    2023-10-23
    java
  • MySQL 处理重复数据的方法(防止、删除)
    有些 MySQL 数据表中可能存在重复的记录,有些情况我们允许重复数据的存在,但有时候我们也需要删除这些重复的数据。 本章节我们将为大家介绍如何防止数据表出现重复数据及如何删除数据表中的重复数据。 防止表中出现重复数...
    99+
    2022-05-14
    MySQL 处理重复数据 MySQL 防止重复数据 MySQL 删除重复数据
  • MYSQL中怎么插入处理重复键值
    MYSQL中怎么插入处理重复键值,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。当unique列在一个UNIQUE键上插入包含重复值的记录时...
    99+
    2022-10-18
  • 详解MySql如何不插入重复数据
    目录1、insert ignore into2、on duplicate key update3、insert ... select ... where not exist4、replace into...
    99+
    2023-01-17
    MySql不插入重复数据 MySql重复数据
  • html中怎么防止重复提交
    这篇文章将为大家详细讲解有关html中怎么防止重复提交,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 1、禁掉提交按钮。表单提交后使用Javascript使提交按钮di...
    99+
    2022-10-19
  • MySQL:插入数据insert ignore,重复数据自动忽略
    MySQL中插入数据,如果插入的数据在表中已经存在(主键或者唯一键已存在),使用insert ignore 语法可以忽略插入重复的数据。 insert ignore 语法 insert ignore into table_name valu...
    99+
    2023-08-30
    mysql
  • node-mysql中怎么防止SQL注入
    node-mysql中怎么防止SQL注入,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。SQL注入简介SQL注入是比较常见的网络...
    99+
    2022-10-18
  • Spring Boot中怎么防止重复提交
    这期内容当中小编将会给大家带来有关Spring Boot中怎么防止重复提交,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。思路自定义注解 @NoRepeatSubmit 标记所有Controller中的提交...
    99+
    2023-06-19
  • MySQL数据库中怎么避免写入重复数据
    MySQL数据库中怎么避免写入重复数据,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。我们在 MySQL数据库进行表设...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作