首页 > 数据库 >MySQL如果数据存在则更新,不存在则插入

MySQL如果数据存在则更新,不存在则插入

时间:2024-03-11 17:22:07浏览次数:24  
标签:存在 name 索引 mobile into 插入 MySQL 默认值

如果数据存在则更新,不存在则插入,MySQL有duplicate、replace into、replace三种方式如何更新数据?
insert ignore into 又是如何插入数据的呢?

准备表和基础数据

测试MySQL版本:8.0.35

use testdb;
#drop table tb_student;
CREATE TABLE `tb_student` (
  `id` int NOT NULL AUTO_INCREMENT COMMENT '自增',
  `num` int not null default 0 COMMENT '',
  `name` varchar(30) DEFAULT '' COMMENT 'appid',
  `address` varchar(100) default '' COMMENT '家庭地址',
  `mobile` varchar(30) DEFAULT '' COMMENT '手机号',
   primary key (id),
   unique key idx_num(num)
   ) ENGINE=InnoDB comment ='学生信息';
   
select * from tb_student;

测试 INSERT INTO ... ON DUPLICATE KEY UPDATE

功能: MySQL语法支持如果数据存在则更新,不存在则插入,首先判断数据存在还是不存在的那个字段要设置成unique索引。
语法: INSERT INTO 表名(唯一索引列, 列2, 列3) VALUE(值1, 值2, 值3) ON DUPLICATE KEY UPDATE 列=值, 列=值

初始化第一条数据

insert into tb_student (num,name,address,mobile)values(1,'张三','上海','18111111111');

不存在则插入

insert into tb_student(num,name,mobile) values(10,'李四','13100000000') on duplicate key update name='李四',mobile='1310000000';

存在则更新

从下面的结果可以看出,第二条记录主键id=2并没有变化,on duyplicate key update 直接在原记录上更新字段值。

insert into tb_student(num,name,mobile) values(10,'李四','13188888888') on duplicate key update name='李四',mobile='13188888888';

INSERT部分,未指明唯一索引列有两种情况:

  1. 如果表中不存在索引列默认值(这里是int,默认值指定的是0)的记录,则直接插入,索引列为默认值;
  2. 如果表中存在索引列默认值记录时,则更新索引字段为默认值记录的其他数据。

insert into tb_student(id,name,mobile) values(3,'王五','15611111111') on duplicate key update name='王五',mobile='15611111111';

第二次未指明唯一索引列插入数据,从下面的结果看出,王五的数据被刘麻子的数据更新掉了。

insert into tb_student(id,name,mobile) values(4,'刘麻子','15899999999') on duplicate key update name='刘麻子',mobile='15899999999';

on duplicate key update特点
  • DUPLICATE不会删除原有的记录。即:不会破坏索引。
  • 不指定唯一索引列时,直接将数据插入表中,索引列是默认值,如果表中已经存在索引列默认值时,就将索引列为默认值的数据更新掉。

测试 REPLACE INTO

REPLACE INTO 主要作用类似 INSERT 插入操作。主要的区别是 REPLACE INTO 会根据主键或者唯一索引检查数据是否存在,如果存在就先删除再更新。

  • 语法:REPLACE INTO 表名称(列1, 列2, 列3) VALUES(值1, 值2, 值3)
不存在则插入

replace into tb_student(num, name, mobile) VALUES(30, '刘备', '13122222222');

注意:此时的主键id=4

存在则先删除后插入

注意:从下面的结果上看,此时的主键id=4的一条记录被删除,重新插入了一条主键id=5的新记录。

replace into tb_student(num, name, mobile) VALUES(30, '刘备', '13122222222');

REPLACE INTO 特点

REPLACE INTO底层是先删除后插入数据,会破坏索引、重新维护索引。
必须要有主键或唯一索引才能有效,否则replace into就只新增了。
测试REPLACE
replace是mysql 里面处理字符串比较常用的函数,可以替换字符串中的内容。类似的处理字符串的还有trim截取操作。

  • 语法:replace(object,search,replace)
查询结果替换

select replace('aaabbbcccc','b','d');

更新数据

update tb_student set address=replace(address,'上','青') where id=1;

测试insert ignore into

如果插入的数据在表中已经存在(主键或者唯一键已存在),使用insert ignore 语法可以忽略插入重复的数据。

  • 语法:insert ignore into table_name values…
主键不冲突,直接插入

insert ignore into tb_student(id, num,name, mobile) VALUES(6, 40,'张飞', '13144444444');

主键冲突,忽略插入

insert ignore into tb_student(id, num,name, mobile) VALUES(6, 40,'赵云', '13155555555');

去掉ignore,SQL报异常

insert into tb_student(id, num,name, mobile) VALUES(6, 40,'赵云', '13155555555');

插入语句不指定索引列时的两种情况
  1. 如果表中不存在索引列默认值(这里是int,默认值指定的是0)的记录,则直接插入,索引列为默认值;
  2. 如果表中存在索引列默认值记录时,则插入不成功,因为和默认值的唯一索引冲突了。

总结:

on duplicate key update特点
  • DUPLICATE不会删除原有的记录。即:不会破坏索引。
  • 不指定唯一索引列时,直接将数据插入表中,索引列是默认值,如果表中已经存在索引列默认值时,就将索引列为默认值的数据更新掉。
replace into特点
  • REPLACE INTO底层是先删除后插入数据,会破坏索引、重新维护索引。
  • 必须要有主键或唯一索引才能有效,否则replace into就只新增了。
replace特点
  • replace是MySQL里面处理字符串比较常用的函数,可以替换字符串中的内容。
insert ignore into特点
  • 主键冲突时,忽略本次插入的数据,否则正常插入。

标签:存在,name,索引,mobile,into,插入,MySQL,默认值
From: https://www.cnblogs.com/xiongzaiqiren/p/18066619

相关文章

  • MySQL如何选择时间类型
    日常业务中经常需要记录时间,如订单生成时间、记录保存时间、更新时间等。如何选择MySQL表的时间字段类型呢?一句话,看业务,具体是看业务是否会跨时区。MySQL的日期类型可以用于记录日期的格式有:Datatype实例备注DATE'0000-00-00'日期(年月日)TIME'00:00:00'......
  • MySQL 进阶实战
    目录1.数据库设计与规范化1.1.实体关系模型(ER模型)简介1.2.数据库设计的范式化过程1.3.设计常见问题和解决方案2.高级SQL技巧2.1.聚合函数和分组查询2.2.子查询和联合查询2.3.视图的创建和使用2.4.存储过程和触发器的概念3.数据库连接与应用开发3.1.使用编程......
  • MySQL分组之后按照固定顺序排序 FIELD
    以下回答来自通义千问:要按照特定顺序显示type字段的统计结果,MySQL并没有提供直接按指定顺序进行GROUPBY的方法。但是,你可以结合ORDERBY语句和FIELD()函数来实现这一需求。FIELD()函数可以将某个字段的值与一系列指定值进行比较,并按照指定值的顺序排序。假设你希望固定的type顺......
  • mysql5.7MHA配置
    准备工作,三台服务器,安装mysql5.7-glibc版本,做主从配置,用gtid模式。安装mysql1、准备安装包[root@hk2install]#llmysql-5.7.32-linux-glibc2.12-x86_64.tar.gz-rw-r--r--1rootroot661214270Jan2019:59mysql-5.7.32-linux-glibc2.12-x86_64.tar.gz 2、解压缩,环......
  • 找不到包 Microsoft.NETCore.App.Crossgen2.win-x64。源 Microsoft Visual Studio Off
    问题找不到包System.IO.Packaging,源MicrosoftVisualStudioOffilinePackages中不存在具有此ID的包 解决打开工具-Nuget相关可以尝试再命令行里用 nugetrestore但是这种情况应该是没有设置源。在选项里面,新建一个程序包源,填写以下源地址(或者其他nuget源)就能修复。......
  • java: 程序包com.sun.org.slf4j.internal不存在
    java:程序包com.sun.org.slf4j.internal不存在事件之由来问题之分析处理之方案收工事件之由来拉完别人的项目后,启动不了了,报错提示:java:程序包com.sun.org.slf4j.internal不存在1问题之分析就是别人用lombok了同时使用slf4j和lombok的时候会出现这个问题原因是slf4j和lombok自......
  • MySQL实现事务隔离的原理
    一、readview四个字段create_trx_id:创建该readview的事务的事务idm_ids:创建readview时,当前数据库中的活跃事务(指启动但还没提交的事务)min_trx_id:m_ids的最小值max_trx_id:创建readview后,下一个事务的id二、聚簇索引的隐藏列trx_id:最近一次改动该聚簇索引记录的事务idrol......
  • Mysql和Clickhouse数据查询-按照时间分组统计并且对无无数据的日期补0
      最近在做数据查询需求的时候,遇到按照时间分组查询统计指标的需求,比如说查询模块的最近15天访问数据量,没有数据的日期补0,以前对于这种类似的需求都是通过代码来补数据,想试试sql实现这种查询,因此查询了不少文章,对于类似实现方法的文章网上也有很多,差异也很多,因此这篇文章只......
  • 关于"李彦宏"的“程序员”职业未来将不复存在的言论的思考
    在3月9日央视的《对话》·开年说节目上,百度创始人、董事长兼CEO李彦宏表示,以后不会存在“程序员”这种职业了,因为只要会说话,人人都会具备程序员的能力。”李总表达的有2个信息点:1,以后不会有“程序员”这个职业了2,只要会说话,人人都会有程序员的能力 初看心里面波澜澎湃,后来在......
  • MySQL 8.0.26版本升级32版本查询数据为空的跟踪
    某业务系统将MySQL8.0.26升级为GreatSQL8.0.32-24后,某些特定的SQL语句不能查询到数据。经测试MySQL8.0.32也存在相同的问题此BUG已在GreatSQL8.0.32-25版本中解决MySQL8.0.26版本升级32版本查询数据为空的跟踪接到客户反馈的问题后,对问题进行了复现和分析。版本信......