请选择 进入手机版 | 继续访问电脑版

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

[复制链接]
查看129 | 回复19 | 2021-9-13 01:02:18 | 显示全部楼层 |阅读模式

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

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

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

例子:

#表布局 :

  1. CREATE TABLE `t_test` (
  2. `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  3. `name` varchar(1) NOT NULL DEFAULT '',
  4. PRIMARY KEY (`id`),
  5. UNIQUE KEY `idx_name` (`name`) USING BTREE
  6. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4
复制代码

插入第一条记录

  1. INSERT INTO t_test (`name`)VALUES('a')
复制代码

#或者

  1. 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

  1. select replace('www.jb51.net','w','n') from ... ---> nnn.jb51.net
复制代码

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

  1. 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用法内容请搜索 脚本之家从前 的文章或继续欣赏 下面的相干 文章渴望 大家以后多多支持脚本之家!


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
回复

使用道具 举报

avatar gui57 | 2021-9-18 18:24:06 | 显示全部楼层
最近压力山大啊!
回复

使用道具 举报

avatar 醉于山水 | 2021-9-19 06:48:52 | 显示全部楼层
支持一下!
回复

使用道具 举报

avatar 边锋1 | 2021-9-30 15:41:06 | 显示全部楼层
雷锋做好事不留名,都写在帖子里!
回复

使用道具 举报

avatar 木头哈喇子崭 | 2021-10-1 10:31:34 | 显示全部楼层
回帖也有有水平的!
回复

使用道具 举报

avatar 坏坏的猪蹄肇 | 2021-10-1 22:01:24 | 显示全部楼层
admin楼主很有经验啊!
回复

使用道具 举报

avatar 安静的小女子 | 2021-10-3 12:13:23 | 显示全部楼层
admin楼主是在找骂么?
回复

使用道具 举报

avatar 薛建朝 | 2021-10-4 15:15:58 | 显示全部楼层
赞一个!
回复

使用道具 举报

avatar 梦的衣裳323 | 2021-10-6 01:11:00 | 显示全部楼层
听admin楼主一席话,省我十本书!
回复

使用道具 举报

avatar 直子的爱本 | 2021-10-6 20:17:58 | 显示全部楼层
楼上的能详细介绍一下么?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则