MySQL into_Mysql中replace与replace into用法案例详解


Posted in MySQL onSeptember 14, 2021

Mysql replace与replace into都是经常会用到的功能;replace其实是做了一次update操作,而不是先delete再insert;而replace into其实与insert into很相像,但对于replace into,假如表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。

replace是mysql 里面处理字符串比较常用的函数,可以替换字符串中的内容。类似的处理字符串的还有trim截取操作,这里就不在多说。

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

例子:

#表结构:

CREATE TABLE `t_test` (

`id` int(11) unsigned NOT NULL AUTO_INCREMENT,

`name` varchar(1) NOT NULL DEFAULT '',

PRIMARY KEY (`id`),

UNIQUE KEY `idx_name` (`name`) USING BTREE

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4

插入第一条记录

INSERT INTO t_test (`name`)VALUES('a')

#或者

REPLACE INTO t_test (`name`)VALUES('a')

采用上面的方式插入二条记录,insert into 会提示错误:1062 - Duplicate entry ‘a' for key ‘idx_name', Time: 0.001000s。使用replace into则会正常执行,只是id自增长1。

ps:replace into 中into关键字可以省略的,看起来一样,使用有点区别

一、replace(object,search,replace)

把object中出现search的全部替换为replace

select replace('www.3water.com','w','n') from ...    --->   nnn.3water.com

例:把表table中的name字段中的detail替换为description

update table set name=replace(name,'detail','description')

二、replace into

相当于:if not exists (select 1 from t where id = 1) insert into t(id, update_time) values(1, getdate()) else update t set update_time = getdate() where id = 1;

REPLACE的运行与INSERT很相像。如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。

注意,除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用一个REPLACE语句没有意义。该语句会与INSERT相同,因为没有索引被用于确定是否新行复制了其它的行。

所有列的值均取自在REPLACE INTO语句中被指定的值。所有缺失的列被设置为各自的默认值,这和INSERT INTO一样。您不能从当前行中引用值,也不能在新行中使用值。如果您使用一个例如“SET col_name = col_name + 1”的赋值,则对位于右侧的列名称的引用会被作为DEFAULT(col_name)处理。因此,该赋值相当于SET col_name = DEFAULT(col_name) + 1。

使用REPLACE INTO,必须拥有表的INSERT和DELETE权限。

REPLACE语句会返回一个数,来指示受影响的行的数目。该数是被删除和被插入的行数的和。如果对于一个单行REPLACE该数为1,则一行被插入,同时没有行被删除。如果该数大于1,则在新行被插入前,有一个或多个旧行被删除。如果表包含多个唯一索引,并且新行复制了在不同的唯一索引中的不同旧行的值,则有可能是一个单一行替换了多个旧行。

受影响的行数可以容易地确定是否REPLACE只添加了一行,或者是否REPLACE也替换了其它行:检查该数是否为1(添加)或更大(替换)。

目前,您不能在一个子查询中,向一个表中更换,同时从同一个表中选择。

以下是所用算法的更详细的说明(该算法也用于LOAD DATA...REPLACE):

1. 尝试把新行插入到表中

2. 当因为对于主键或唯一关键字出现重复关键字错误而造成插入失败时:

a. 从表中删除含有重复关键字值的冲突行

b. 再次尝试把新行插入到表中

三种形式:

  1. replace into tbl_name(col_name, ...) values(...)
  2. replace into tbl_name(col_name, ...) select ...
  3. replace into tbl_name set col_name=value, ...

PS:

mysql中常用的三种插入数据的语句:

insert into表示插入数据,数据库会检查主键,如果出现重复会报错;

replace into表示插入替换数据,需求表中有PrimaryKey,或者unique索引,如果数据库已经存在数据,则用新数据替换,如果没有数据效果则和insert into一样;

insert ignore表示,如果中已经存在相同的记录,则忽略当前新数据;

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。如果你想了解更多相关内容请查看下面相关链接

到此这篇关于MySQL into_Mysql中replace与replace into用法案例详解的文章就介绍到这了,更多相关MySQL into_Mysql中replace与replace into用法内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

MySQL 相关文章推荐
MySQL 十大常用字符串函数详解
Jun 30 MySQL
低版本Druid连接池+MySQL驱动8.0导致线程阻塞、性能受限
Jul 01 MySQL
sql注入教程之类型以及提交注入
Aug 02 MySQL
浅谈MySQL之select优化方案
Aug 07 MySQL
Mysql排序的特性详情
Nov 01 MySQL
MySQL笔记 —SQL运算符
Jan 18 MySQL
JMeter对MySQL数据库进行压力测试的实现步骤
Jan 22 MySQL
一文搞清楚MySQL count(*)、count(1)、count(col)区别
Mar 03 MySQL
MySQL慢查询优化解决问题
Mar 17 MySQL
Mysql事务索引知识汇总
Mar 17 MySQL
解决MySQL报“too many connections“错误
Apr 19 MySQL
面试官问我Mysql的存储引擎了解多少
Aug 05 MySQL
MYSQL 的10大经典优化案例场景实战
Sep 14 #MySQL
MySQL中连接查询和子查询的问题
mysql配置SSL证书登录的实现
MySQL约束超详解
Sep 04 #MySQL
MySQL中的隐藏列的具体查看
Sep 04 #MySQL
Mysql实现简易版搜索引擎的示例代码
Aug 30 #MySQL
详细聊聊MySQL中慢SQL优化的方向
Aug 30 #MySQL
You might like
繁体中文转换为简体中文的PHP函数
2006/10/09 PHP
来自PHP.NET的入门教程
2006/10/09 PHP
php 获取页面中指定内容的实现类
2014/01/23 PHP
跟我学Laravel之快速入门
2014/10/15 PHP
wamp服务器访问php非常缓慢的解决过程
2015/07/01 PHP
js GridView 实现自动计算操作代码
2009/03/25 Javascript
js控制容器隐藏出现防止样式变化的两种方法
2014/04/25 Javascript
JavaScript中的数组遍历forEach()与map()方法以及兼容写法介绍
2016/05/19 Javascript
JavaScript获取IP获取的是IPV6 如何校验
2016/06/12 Javascript
AngularJS入门教程之模块化操作用法示例
2016/11/02 Javascript
JS字符串去除连续或全部重复字符的实例
2018/03/08 Javascript
js前端如何写一个精确的倒计时代码
2019/10/25 Javascript
浅谈小程序globalData的那些事儿
2019/11/01 Javascript
深入理解Antd-Select组件的用法
2020/02/25 Javascript
[00:08]DOTA2勇士令状等级奖励“天外飞星”
2019/05/24 DOTA
Python实现自定义函数的5种常见形式分析
2018/06/16 Python
Python 实现中值滤波、均值滤波的方法
2019/01/09 Python
代码详解django中数据库设置
2019/01/28 Python
python的sorted用法详解
2019/06/25 Python
Python实现时间序列可视化的方法
2019/08/06 Python
django项目中使用手机号登录的实例代码
2019/08/15 Python
Python3多线程版TCP端口扫描器
2019/08/31 Python
详解KMP算法以及python如何实现
2020/09/18 Python
TCP/IP中的TCP和IP分别承担什么责任
2012/04/21 面试题
毕业生个人求职的自我评价
2013/10/28 职场文书
大学生实习感言
2014/01/16 职场文书
移风易俗倡议书
2014/04/15 职场文书
心理健康活动总结
2014/04/30 职场文书
党员公开承诺书内容
2014/05/20 职场文书
大学生学雷锋活动总结
2014/06/26 职场文书
2015年党员干部承诺书
2015/01/21 职场文书
创业分两种人:那么哪些适合创业?,哪些适合不适合创业呢?
2019/08/23 职场文书
pytorch 6 batch_train 批训练操作
2021/05/28 Python
解决使用了nginx获取IP地址都是127.0.0.1 的问题
2021/09/25 Servers
分享一个vue实现的记事本功能案例
2022/04/11 Vue.js
Tomcat项目启动失败的原因和解决办法
2022/04/20 Servers