MySQL中replace into语句的用法详解

 更新时间:2014年08月26日 10:55:51   投稿:junjie  
这篇文章主要介绍了MySQL中replace into语句的用法详解,本文讲解了replace into语句的多种写法,replace into语句的作用等内容,需要的朋友可以参考下

在向表中插入数据的时候,经常遇到这样的情况:

1、首先判断数据是否存在;
2、如果不存在,则插入;
3、如果存在,则更新。
 
在 SQL Server 中可以这样写:

复制代码 代码如下:

if not exists (select 1 from table where id = 1) insert into table(id, update_time) values(1, getdate()) else update table set update_time = getdate() where id = 1

在MySQL 中也可以先select,判断是否存在,存在则 update 否则 insert
但在MySQL 中有更简单的方法,使用 replace into关键字
复制代码 代码如下:
replace into table(id, update_time) values(1, now());


复制代码 代码如下:

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

replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中。

1、如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。
2、 否则,直接插入新数据。

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

复制代码 代码如下:

1. replace into table(col, ...) values(...)
2. replace into table(col, ...) select ...
3. replace into table set col=value, ...

前两种形式用的多些。其中 “into” 关键字可以省略,不过最好加上 “into”,这样意思更加直观。
另外,对于那些没有给予值的列,MySQL 将自动为这些列赋上默认值。
 
可惜的是replace不支持update某些特性,也就不能直接当作update使用:

常见update写法:update table set col=col+1 where id=1;
使用replace into不支持这样的写法:replace into table set col=col+1,id=1;

1、首先判断数据是否存在;(没问题)
2、如果不存在,则插入;(没问题)
3、如果存在,某字段值在原来的基础上加上或减去某个数,如加一操作。(不支持)

相关文章

  • mysql基础架构教程之查询语句执行的流程详解

    mysql基础架构教程之查询语句执行的流程详解

    这篇文章主要给大家介绍了关于mysql基础架构教程之查询语句执行流程的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧
    2018-11-11
  • MySQL千万级数据从190秒优化到1秒的全过程

    MySQL千万级数据从190秒优化到1秒的全过程

    优化MySQL千万级数据策略还是比较多的,分表分库,创建中间表,汇总表以及修改为多个子查询,这里讨论的情况是在MySQL一张表的数据达到千万级别,在这样的情况下,开发者可以尝试通过优化SQL来达到查询的目的,所以本文给大家介绍了MySQL千万级数据从190秒优化到1秒的全过程
    2024-04-04
  • 聊聊MySQL的COUNT(*)的性能

    聊聊MySQL的COUNT(*)的性能

    这篇文章主要介绍了聊聊MySQL的COUNT(*)的性能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • windows7下启动mysql服务出现服务名无效的原因及解决方法

    windows7下启动mysql服务出现服务名无效的原因及解决方法

    这篇文章主要介绍了windows7下启动mysql服务出现服务名无效的原因及解决方法,需要的朋友可以参考下
    2014-06-06
  • 同时运行多个MySQL服务器的方法

    同时运行多个MySQL服务器的方法

    在同一台机器上运行多个有些情况下你可能想要在同一台机器上运行多个服务器。例如,你可能想要测试一个新的MySQL版本而让你现有生产系统的设置不受到干扰, 或你可能是想要为不同的客户提供独立的MySQL安装一个因特网服务供应商。
    2008-05-05
  • SQLyog连接MySQL8.0+报错:错误号码2058的解决方案

    SQLyog连接MySQL8.0+报错:错误号码2058的解决方案

    本文将总结如何解决 SQLyog 连接 MySQL8.0+ 时报错:错误号码2058,文中通过图文结合和代码示例给大家总结了三种解决方案,具有一定的参考价值,需要的朋友可以参考下
    2023-12-12
  • MySQL中如何进行SQL调优举例详解

    MySQL中如何进行SQL调优举例详解

    这篇文章主要介绍了SQL调优的几种方法,包括合理设计索引,避免SELECT*,避免在SQL中进行函数计算等操作,避免使用%LIKE,注意联合索引需满足最左匹配原则,不要对无索引字段进行排序操作,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-01-01
  • SQL字符型字段按数字型字段排序实现方法

    SQL字符型字段按数字型字段排序实现方法

    由于是按字母顺序排列,所以123排在了2的前面,显然不符合我们的要求,那么怎样才能按照我们预想的数字顺序排序呢
    2013-03-03
  • 详解 Mysql中的delimiter定义及作用

    详解 Mysql中的delimiter定义及作用

    delimiter是mysql分隔符,在mysql客户端中分隔符默认是分号(;)。如果一次输入的语句较多,并且语句中间有分号,这时需要新指定一个特殊的分隔符。这篇文章给大家介绍了Mysql中的delimiter的作用,感兴趣的朋友一起看看吧
    2018-09-09
  • Linux服务上MySQL启动、重启和关闭的操作方法

    Linux服务上MySQL启动、重启和关闭的操作方法

    MySQL是一种广泛使用的开源关系型数据库管理系统,常用于各种规模的应用程序中,在Linux服务器上管理MySQL服务是一个基本的运维任务,本文将详细介绍如何在Linux系统上启动、重启和关闭MySQL服务,涵盖不同Linux发行版(如Ubuntu和CentOS)的操作方法
    2024-11-11

最新评论