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

作者:京脉圈 时间:2024-01-26 20:10:00 

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.jb51.net','w','n') from ...    --->   nnn.jb51.net

例:把表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表示,如果中已经存在相同的记录,则忽略当前新数据;

来源:https://blog.csdn.net/weixin_34162851/article/details/113032144

标签:mysql,into,Mysql,replace,replace,into
0
投稿

猜你喜欢

  • Python matplotlib图例放在外侧保存时显示不完整问题解决

    2023-10-08 14:05:35
  • win10环境下配置vscode python开发环境的教程详解

    2022-09-06 21:19:49
  • SpringBoot图文并茂详解如何引入mybatis与连接Mysql数据库

    2024-01-25 15:07:32
  • js模拟实现Array的sort方法

    2024-04-10 11:03:22
  • python使用tcp传输图片数据

    2023-08-09 06:33:48
  • MySQL中导出用户权限设置的脚本分享

    2024-01-21 15:29:04
  • mysql ERROR 1045 (28000)问题的解决方法

    2024-01-16 23:24:32
  • 几个常见的MySQL的可优化点归纳总结

    2024-01-13 11:32:14
  • 编写Python脚本抓取网络小说来制作自己的阅读器

    2022-11-06 18:51:03
  • Python 从subprocess运行的子进程中实时获取输出的例子

    2023-12-24 18:31:10
  • 数据库更新Sqlserver脚本总结

    2024-01-13 15:05:25
  • 大前端时代搞定PC/Mac端开发,我有绝招(收藏版)

    2023-02-13 08:38:58
  • pytorch 实现多个Dataloader同时训练

    2023-11-14 23:33:21
  • mysql myisam优化设置

    2010-03-13 16:59:00
  • JavaScript设计模式之适配器模式介绍

    2023-08-12 06:36:09
  • mysql运行net start mysql报服务名无效的解决办法

    2024-01-17 06:12:15
  • 交互设计实用指南系列(8)—深广度平衡

    2010-02-01 12:59:00
  • 一文带你了解Python中的输入与输出

    2023-11-26 12:05:24
  • python热力图实现的完整实例

    2023-03-02 17:10:35
  • 基于jupyter代码无法在pycharm中运行的解决方法

    2023-09-15 06:46:38
  • asp之家 网络编程 m.aspxhome.com