zoukankan      html  css  js  c++  java
  • MySQL replace into 说明(insert into 增强版)

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

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

    在 SQL Server 中能够这样处理:

    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
    

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

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

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

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

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

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

    MySQL replace into 有三种形式:

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

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

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

    replace具体说明:

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

    REPLACE作品全然一样 的INSERT,但假设旧表中的行具有同样的值作为一个新行 PRIMARY KEYUNIQUE 索引。旧行插入新行之前删除。请參见 第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状态变量。


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

  • 相关阅读:
    TableExport导出失败问题
    gitlab备份、恢复、升级
    读书笔记一【加密——替换法】
    读书笔记一【加密——换位法】
    解决Kettle ETL数据乱码
    SQL中exsit和in
    Centos下搭建邮件服务器
    2018总结及2019计划
    mac安装gcc
    Vue.js学习 Item11 – 组件与组件间的通信
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4658948.html
Copyright © 2011-2022 走看看