我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql中replaceinto与insertinto区别

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql中replaceinto与insertinto区别

replace into 遇到主键或唯一索引冲突时,会先删除数据,再插入新数据

insert into 遇到主键或唯一索引冲突时,会直接报错,不插入数据

案例:

新建一个test表,三个字段,id,title,uid, id是自增的主键,uid是唯一索引;

CREATE TABLE `test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `title` varchar(255) DEFAULT NULL,
  `uid` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `sss` (`uid`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

插入2条数据

insert into  test(title,uid) VALUES ('张三','001');
insert into  test(title,uid) VALUES ('张三','002');

使用 insert into插入数据时,报错

insert into test(title,uid) VALUES ('李四','001');

使用 replace into插入数据时:

replace into test(title,uid) VALUES ('李四','001');

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

要注意的是:插入数据的表必须有主键或者是唯一索引!否则的话,replace into 会直接插入数据,这将导致表中出现重复的数据。

到此这篇关于mysql中replace into与insert into区别的文章就介绍到这了,更多相关mysql replace into与insert into内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql中replaceinto与insertinto区别

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

下载Word文档

猜你喜欢

mysql中replaceinto与insertinto区别

本文主要介绍了mysql中replaceinto与insertinto区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-18

mysql中null与(null的区别

mysql 中 null 和 (null) 区别如下:null 表示未知值,而 (null) 表示明确空值。null 不占用存储空间,而 (null) 占用一个字节。null 不等于任何值,而 (null) 等于它自己。null 用于表示缺
mysql中null与(null的区别
2024-05-01

mysql中null与(null)的区别

在 mysql 中,null 代表空值,不占用空间,而 (null) 是空字符串值,占用 1 字节空间。它们的区别包括:存储方式不同、比较方式不同、插入方式不同、聚合函数处理方式不同、索引使用不同。MySQL 中 NULL 与 (NULL)
mysql中null与(null)的区别
2024-05-01

mysql中replace into与insert into区别

replace into 遇到主键或唯一索引冲突时,会先删除数据,再插入新数据insert into 遇到主键或唯一索引冲突时,会直接报错,不插入数据案例:新建一个test表,三个字段,id,title,uid, id是自增的主键,u
2023-01-18

mysql中 ${param}与#{param}使用区别

${param}传递的参数会被当成sql语句中的一部分,比如传递表名,字段名 例子:(传入值为id) order by ${param} 则解析成的sql为: order by id#{parm}传入的数据都当成一个字符串,会对自动传入的数
2022-05-24

mysql中datatime与timestamp有什么区别

这篇文章主要介绍了mysql中datatime与timestamp有什么区别,编程网小编觉得不错,现在分享给大家,也给大家做个参考,一起跟随编程网小编来看看吧!mysql中有三种日期类型:date(年-月-日)create table te
2023-06-06

MySQL 中 SELECT DISTINCT 与 GROUP BY 的区别?

SELECT DISTINCT 可用于给出不同的值。用它来删除重复的记录并它也可以与聚合函数一起使用。例如:MAX、AVG等。这个都可以应用在单个列上。现在,我正在创建一个表以对列使用 SELECT DISTINCT。创建一个表CRE
2023-10-22

mysql中 datatime与timestamp的区别说明

mysql中有三种日期类型: date(年-月-日) create table test(hiredate date); datetime(日期时间类型) create table test(hiredate datetime) times
2022-05-27

关于Mysql中current_time/current_date()与now()区别

目录current_date()只显示的是当前时间的日期例如:select current_date() from a ;结果:2021-08-25current_time()只javascript显示当前时间的时分秒例如:sel
2023-04-28

MySQL中replace into与replace区别详解

目录0.故事的背景1.replace into 的使用方法2.有唯一索引时—replace into & 与replace 效果3.没有唯一索引时—replace into 与 replace1).replace函数
2022-08-19

mysql中LEAVE与ITERATE有什么区别

mysql中LEAVE与ITERATE有什么区别?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。LEAVE语句LEAVE语句主要用于跳出循环控制。其语法形式如下:LEAVE la
2023-06-14

编程热搜

目录