`

MySQL replace into 的用法

阅读更多

MySQL replace into 的用法

 

语法:

Sql代码 
  1. REPLACE [LOW_PRIORITY | DELAYED]  
  2.     [INTO] tbl_name  
  3.     [PARTITION (partition_name,...)]  
  4.     [(col_name,...)]  
  5.     {VALUES | VALUE} ({expr | DEFAULT},...),(...),...  

 

replace 和insert的作用是一样的,都是插入数据,当用insert 插入数据时,如果插入的记录包含的主键或者唯一索引已经存在,则会插入失败

例如:

 

 

而使用replace,如果出现这种情况,那么首先已存在的记录会被删掉,然后再插入新的记录

例如:



 可以看到affected rows为2,replace的affected rows = 被删除的行数 + 新插入的行数

 

要实现已存在则更新的的效果还可以用insert into ... on duplicate key update ...的语法,例如

 

values函数的参数是列名,返回当前插入的行所对应的该列的值 

 

可以看到如果当primary key已存在时,不会进行插入,而是执行update后面的逻辑

 

0
1
分享到:
评论

相关推荐

    MySQL replace into 用法.txt

    根据提供的文件信息,本文将详细解释 MySQL 中 `REPLACE INTO` 的使用方法及特性,并对比其与 `INSERT INTO` 的不同之处。 ### MySQL REPLACE INTO 介绍 #### 1. REPLACE INTO 的基本概念 `REPLACE INTO` 是 ...

    MySQL replace into 语句浅析(一)

    本篇文章将深入浅出地解析`REPLACE INTO`的原理、使用方法以及适用场景,并通过实例来演示其工作方式。 ### 一、介绍 `REPLACE INTO`语句在MySQL中主要用于处理插入数据时可能出现的主键或唯一索引冲突问题。当...

    浅析MySQL replace into 的用法

    在 SQL Server 中可以这样处理: 代码如下: if not exists (select 1 from t where id = 1) ...MySQL 中有更简单的方法: replace into 代码如下: replace into t(id, update_time) values(1, now());或 repl

    Mysql中replace与replace into的用法讲解

    MySQL中的`REPLACE`和`REPLACE INTO`是两种用于数据插入或更新的SQL语句,它们在处理数据冲突时有独特的策略。首先,我们来分别解析这两个命令。 `REPLACE`函数通常指的是字符串处理函数,它在MySQL中用于替换字符...

    mysql中replace into的用法详解

    replace into语句会根据唯一键/主键删除原有的一条记录, 并且插入一条新的记录来替换原记录。如果没有表不存在唯一键/主键 或者 插入的数据唯一键/主键没有重复的,那么会新增一条记录。 新建一个test表,三个字段...

    mysql 替换字段部分内容及mysql 替换函数replace()

    [mysql]replace的用法(替换某字段部分内容) [mysql]replace的用法 1.replace into  replace into table (id,name) values(‘1′,’aa’),(‘2′,’bb’)  此语句的作用是向表table中插入两条记录。如果主键id为...

    MySQL中replace into语句的用法详解

    MySQL中的`REPLACE INTO`语句是一个非常实用的命令,它结合了`INSERT`和`UPDATE`的功能,简化了在数据库表中处理已有数据的工作流程。这个语句主要用于当你要插入一条新记录,但该记录的主键或唯一索引字段与现有...

    mysql 的replace into实例详解

    总的来说,`REPLACE INTO`是MySQL中处理数据插入和更新的一个强大工具,但使用时需谨慎,因为它会彻底删除已存在的行。正确理解和使用`REPLACE INTO`能帮助你在数据库管理中避免数据冗余和不一致,提高数据的整洁性...

    mysql 中 replace into 与 insert into on duplicate key update 的用法和不同点实例分析

    在MySQL中,`REPLACE INTO` 和 `INSERT INTO ON DUPLICATE KEY UPDATE` 是两种处理数据插入时冲突的方法,主要用于处理当试图插入一条记录,而该记录的唯一键或主键已经在表中存在的情况。这两种方法都可以实现如果...

    mysql 批量更新及效率对比

    这种方法使用 Replace Into 或 Insert Into ... On Duplicate Key Update 语句来批量更新记录,例如: ```sql replace into test_tbl (id, dr) values (1, '2'), (2, '3'), ... (x, 'y'); ``` 或者: ```sql ...

    MySQL replace函数替换字符串语句的用法

    需要注意的是,`REPLACE`函数与`INSERT`语句的`REPLACE INTO`形式不同,后者会在遇到主键或唯一索引冲突时先删除已存在的行,然后再插入新行。而单纯的`REPLACE`函数只做字符串替换,不涉及行的增删。 当执行`...

    insert 和replace的区别及用法

    INSERT 和 REPLACE 语句在 MySQL 中的使用和区别 INSERT 语句是 MySQL 中最基本的数据插入语句,它有两种基本形式:INSERT INTO 语句和 INSERT SET 语句。INSERT INTO 语句的基本语法是 INSERT INTO tablename(列名...

    MySQL使用Replace操作时造成数据丢失的问题解决

    在问题描述中,开发人员在更新`active_items`表时使用了`REPLACE INTO`语句,导致数据丢失。这是因为`REPLACE`不仅替换指定的字段(如`ad_id`和`score`),还会将所有未指定的字段设置为默认值,从而清空了原有数据...

    insert into … on duplicate key update / replace into 多行数据介绍

    在MySQL数据库中,当我们需要处理批量插入数据时,但又希望在数据已存在时更新其值,可以使用两种特殊语法:`INSERT INTO ... ON DUPLICATE KEY UPDATE` 和 `REPLACE INTO`。这两种方法都可以实现“合并”操作,即在...

Global site tag (gtag.js) - Google Analytics