MySQL避免插入重复记录的方法 (主键/唯一索引重复则忽略此条数据或更新原有数据)

本文主要是介绍MySQL避免插入重复记录的方法 (主键/唯一索引重复则忽略此条数据或更新原有数据),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

表(注意唯一约束)


-- ----------------------------
-- Table structure for star_platform
-- ----------------------------
DROP TABLE IF EXISTS `star_platform`;
CREATE TABLE `star_platform` (`platform_id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主键',`platform_source` int(5) NOT NULL DEFAULT '0' COMMENT '平台编号',`platform_source_name` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '平台名',`note` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '' COMMENT '备注',PRIMARY KEY (`platform_id`),UNIQUE KEY `unique_source` (`platform_source`,`platform_source_name`) USING BTREE COMMENT '用于约束平台唯一性'
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci COMMENT='平台(任务源)';SET FOREIGN_KEY_CHECKS = 1;-- 插入一条初始数据  (Affected rows: 0)
insert into star_platform (platform_source,platform_source_name) values (1,"平台名");-- insert ignore into ...  忽略:忽略主键或唯一索引重复的数据,注意执行结果中的受影响行数 (Affected rows: 0)
insert IGNORE into star_platform (platform_source,platform_source_name) values (1,"平台名");-- replace into ...    有重复数据则替换(删除再插入,注意看主键id值)   受影响行数(Affected rows: 2)
replace into star_platform (platform_source,platform_source_name) values (1,"平台名");-- insert ...  on duplicate key update ...  有重复数据则更新update后的数值 受影响行数(Affected rows: 2)
INSERT INTO star_platform (platform_source, platform_source_name, note)VALUES ( 1, "平台名", "备注")ON DUPLICATE KEY UPDATE platform_source_name = "平台名2",note = "备注2";

 

1、插入或忽略

insert ignore into ...    :主键或唯一索引不重复,执行插入;重复,则不插入,但是会占用一个自增主键值(如:上一条数据主键id值为1,则 ignore 语句执行并忽略一条重复数据后,则再次insert时,id值会是3)

insert IGNORE into star_platform (platform_source,platform_source_name) values (1,"平台名")

2、插入或替换(删除并新增数据)

replace into ...   :主键或唯一索引不重复,执行插入;重复,则先删除重复数据,然后重新插入新数据(主键值会改变)

replace into star_platform (platform_source,platform_source_name) values (1,"平台名")

3、插入或更新

insert ...  on duplicate key update ...  :主键或唯一索引不重复,则插入;重复,则修改UPDATE后的数据(主键值不变

INSERT INTO star_platform (platform_source, platform_source_name, note)
        VALUES ( 1, "平台名", "备注")
        ON DUPLICATE KEY UPDATE platform_source_name = "平台名2",note = "备注2";

 

参考:

https://www.cnblogs.com/prayer21/p/6018864.html

https://www.2cto.com/database/201308/234179.html

这篇关于MySQL避免插入重复记录的方法 (主键/唯一索引重复则忽略此条数据或更新原有数据)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/917643

相关文章

QT移植到RK3568开发板的方法步骤

《QT移植到RK3568开发板的方法步骤》本文主要介绍了QT移植到RK3568开发板的方法步骤,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录前言一、获取SDK1. 安装依赖2. 获取SDK资源包3. SDK工程目录介绍4. 获取补丁包二

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固 通俗易懂版)

《MySQL中实现多表查询的操作方法(配sql+实操图+案例巩固通俗易懂版)》本文主要讲解了MySQL中的多表查询,包括子查询、笛卡尔积、自连接、多表查询的实现方法以及多列子查询等,通过实际例子和操... 目录复合查询1. 回顾查询基本操作group by 分组having1. 显示部门号为10的部门名,员

java导出pdf文件的详细实现方法

《java导出pdf文件的详细实现方法》:本文主要介绍java导出pdf文件的详细实现方法,包括制作模板、获取中文字体文件、实现后端服务以及前端发起请求并生成下载链接,需要的朋友可以参考下... 目录使用注意点包含内容1、制作pdf模板2、获取pdf导出中文需要的文件3、实现4、前端发起请求并生成下载链接使

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

MySQL中COALESCE函数示例详解

《MySQL中COALESCE函数示例详解》COALESCE是一个功能强大且常用的SQL函数,主要用来处理NULL值和实现灵活的值选择策略,能够使查询逻辑更清晰、简洁,:本文主要介绍MySQL中C... 目录语法示例1. 替换 NULL 值2. 用于字段默认值3. 多列优先级4. 结合聚合函数注意事项总结C

通过ibd文件恢复MySql数据的操作方法

《通过ibd文件恢复MySql数据的操作方法》文章介绍通过.ibd文件恢复MySQL数据的过程,包括知道表结构和不知道表结构两种情况,对于知道表结构的情况,可以直接将.ibd文件复制到新的数据库目录并... 目录第一种情况:知道表结构第二种情况:不知道表结构总结今天干了一件大事,安装1Panel导致原来服务

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM