MySQL replace into 说明(insert into 增强版)

在插入数据到一个表时,通常是这种情况:1. 先推断数据是否存在; 2. 假设不存在,则插入;3.假设存在,则更新。

在 SQL Server 中能够这样处理:

  1. if not exists (select 1 from t where id = 1)
  2. insert into t(id, update_time) values(1, getdate())
  3. else
  4. update t set update_time = getdate() where id = 1

那么 MySQL 中怎样实现这种逻辑呢?别着急!

MySQL 中有更简单的方法:
replace into

  1. replace into t(id, update_time) values(1, now());

  1. replace into t(id, update_time) select 1, now();

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

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

MySQL replace into 有三种形式:

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

前两种形式用的多些。当中 “into” keyword能够省略,只是最好加上 “into”。这样意思更加直观。

另外。对于那些没有给予值的列。MySQL 将自己主动为这些列赋上默认值。

replace具体说明:

參考资料:http://dev.mysql.com/doc/refman/5.0/en/replace.html

REPLACE作品全然一样 的INSERT,但假设旧表中的行具有同样的值作为一个新行 PRIMARY
KEY
UNIQUE 索引。旧行插入新行之前删除。请參见 第13.2.5节,“INSERT语法”

REPLACE是一个MySQL扩展SQL标准。它要么插入或删除 和插入。还有一个MySQL扩展到标准的SQL。要么插入或 更新 -请參阅 第13.2.5.3,“INSERT
... ON DUPLICATE KEY UPDATE的SQL语法”

请注意。除非表有一个PRIMARY
KEY
或 UNIQUE索引。使用 REPLACE语句是没有意义的。

它变成相当于INSERT,由于要使用没有索引,以确定新的行是否会复制另外一个。

值的全部列都来自于指定的值 REPLACE语句。

不论什么缺失的列被设置为各自的默认值,就像发生在 INSERT。您不能从当前行參考值,并使用他们的新行。

假设您使用的作业,如设置 COL_NAME = COL_NAME +1,參考列名在右边被视为 默认(COL_NAME,所以转让相当于SET COL_NAME =
DEFAULT(COL_NAME)+1

要使用REPLACE,您必须同一时候拥有INSERT和 DELETE的表的权限。

REPLACE语句返回一个数来表示受影响的行数。

这是删除和插入的行的总和。

假设计数1为单排 更换,连续被插入并没有行被删除。

假设计数插入新行之前大于1。一个或多个旧行被删除。

这是可能的单行替换多个旧行假设表包括多个唯一索引,而且新行复制的值在不同的唯一索引中的不同旧行。

受影响的行数能够非常easy地确定是否 REPLACE仅仅加入了一行。或者是否也换成不论什么行:检查是否计数1(加入)或更大(替换)。

假设您正在使用C
API时,受影响的行数能够通过获得 mysql_affected_rows()函数。

眼下,您不能更换成一个表,并从同一个表中的子查询中选择。

MySQL使用下列算法 REPLACE(和LOAD
DATA ... REPLACE
):

  1. 尝试插入新行插入表

  2. 而插入失败。由于发生在主键或唯一索引的反复键错误:

    1. 从表中删除了反复的键值冲突的行

    2. 再次尝试插入新行插入表

可能的是在一个反复键错误的情况下,存储引擎能够运行REPLACE作为更新,而不是删除加插入,但语义是同样的。有没有比方何存储引擎添加一个可能的差异其它用户可见的效果 Handler_ XXX状态变量。

版权声明:本文博客原创文章。博客,未经同意,不得转载。

MySQL replace into 说明(insert into 增强版)的更多相关文章

  1. MySQL replace into (insert into 的增强版)

    在使用SQL语句进行数据表插入insert操作时,如果表中定义了主键,插入具有相同主键的记录会报错:  Error Code: 1062. Duplicate entry 'XXXXX' for ke ...

  2. MySQL replace into 与insert into

    https://blog.csdn.net/helloxiaozhe/article/details/77427266 使用replace带来的问题 1.Replace into 操作在唯一键重复情况 ...

  3. MySQL replace into 用法(insert into 的增强版)

    转 http://blog.csdn.net/risingsun001/article/details/38977797 MySQL replace into 用法(insert into 的增强版) ...

  4. 将表里的数据批量生成INSERT语句的存储过程 增强版

    将表里的数据批量生成INSERT语句的存储过程 增强版 有时候,我们需要将某个表里的数据全部或者根据查询条件导出来,迁移到另一个相同结构的库中 目前SQL Server里面是没有相关的工具根据查询条件 ...

  5. mysql插入数据时 insert IGNORE、ON DUPLICATE KEY UPDATE、replace into

    转: mysql insert时几个操作DELAYED .IGNORE.ON DUPLICATE KEY UPDATE的区别 博客分类: mysql基础应用   mysql insert时几个操作DE ...

  6. 【转】MySQL的Replace into 与Insert into on duplicate key update真正的不同之处

    原文链接:http://www.jb51.net/article/47090.htm   今天听同事介绍oracle到mysql的数据migration,他用了Insert into ..... on ...

  7. 将表里的数据批量生成INSERT语句的存储过程 继续增强版

    文章继续 桦仔兄的文章 将表里的数据批量生成INSERT语句的存储过程 增强版 继续增强... 本来打算将该内容回复于桦仔兄的文章的下面的,但是不知为何博客园就是不让提交!.... 所以在这里贴出来吧 ...

  8. mysql中 REPLACE INTO 和 INSERT INTO 的区别

    mysql中 REPLACE INTO 和 INSERT INTO 的区别 REPLACE INTO 和 INSERT INTO 功能类似,都是像表中插入数据,不同点在于:REPLACE INTO 首 ...

  9. MySQL "replace into" 的坑以及insert相关操作

    下面我们主要说一下在插入时候的几种情况: 1:insert ignore 2:replace into 3:ON DUPLICATE KEY UPDATE 关于insert ignore: 关于rep ...

随机推荐

  1. Error opening zip file or JAR manifest missing : D:\play-1.2.5/framework/play-1.2.5.jar

    play框架写的项目,在eclipse中导入.build-path中全部jar包都加入.执行程序,出现: Error occurred during initialization of VM agen ...

  2. SQL Server 2008 R2 性能计数器详细列表(三)

    原文:SQL Server 2008 R2 性能计数器详细列表(三) SQL Server,Deprecated Features 对象: 监视指定为不推荐使用的功能: SQL Server Depr ...

  3. 深度解析:Android在Mms设置页面更改短信中心号码流程

    相关控件初始化方法:showSmscPref private void showSmscPref() {         int count = MSimTelephonyManager.getDef ...

  4. .NET单元测试艺术(2) - 第一个单元测试

    List 2.1 使用[SetUp]和[TearDown]特性 using System; using System.Collections.Generic; using System.Linq; u ...

  5. kendoui仪表板和直方图 演示样本

    到那个时刻kendeodui我相信大家一定不陌生.该js在绘画方面的好成绩. 现在来看看 它的仪表盘和直方图效果: html和js代码例如以下: <!DOCTYPE html> <h ...

  6. NSIS:IfFileExists+Goto实现简单跳转

    原文 NSIS:IfFileExists+Goto实现简单跳转 在用户手册中有相关示例,但也许有的同学没有发现,那么我再发一个,仅供入门学习参考. IfFileExists 要检测的文件 文件存在时跳 ...

  7. 【MongoDB】Serveral common command of MongoDb

    In the recent days, since the overwork made me exhaused, on arrival to home I will go to bed, which ...

  8. 如何有效地记录 Java SQL 日志(转)

    在常规项目的开发中可能最容易出问题的地方就在于对数据库的处理了,在大部分的环境下,我们对数据库的操作都是使用流行的框架,比如 Hibernate . MyBatis 等.由于各种原因,我们有时会想知道 ...

  9. Android相框 与 源代码结构

    一. Android 相框 Android框架层级 : Android 自下 而 上 分为 4层; -- Linux内核层; -- 各种库 和 Android执行环境层; -- 应用框架层; -- 应 ...

  10. JavaScript编写了一个计时器

    初学JavaScript,用JavaScript编写了一个计时器. 设计思想: 1.借助于Date()对象,来不断获取时间点: 2.然后用两次时间点的毫秒数相减,算出时间差: 3.累加时间差,这样就能 ...