首页 > 数据库 > mysql教程 > MySQL 如何处理 INSERT ... SELECT ... ON DUPLICATE KEY UPDATE 语法?

MySQL 如何处理 INSERT ... SELECT ... ON DUPLICATE KEY UPDATE 语法?

Patricia Arquette
发布: 2024-12-06 06:59:11
原创
649 人浏览过

How Does MySQL Handle INSERT ... SELECT ... ON DUPLICATE KEY UPDATE Syntax?

INSERT ... SELECT ... ON DUPLICATE KEY UPDATE 语法说明

执行 INSERT 查询时,某些列可能已存在于对于目标表,可以使用 ON DUPLICATE KEY UPDATE 子句。此子句允许您指定更新条件和要更新的值。

此类查询中 UPDATE 子句的语法如下:

ON DUPLICATE KEY UPDATE column1=value1, column2=value2, ...;
登录后复制

要理解的关键方面是MySQL 如何引用正在插入和更新的值。默认情况下,等号之前的部分引用 INSERT INTO 子句中指定的列,而等号之后的部分引用 SELECT 子句中指定的列。

例如,考虑以下查询:

INSERT INTO lee(exp_id, created_by, location, animal, starttime, endtime, entct, inact, inadur, inadist, smlct, smldur, smldist, larct, lardur, lardist, emptyct, emptydur)
SELECT id, uid, t.location, t.animal, t.starttime, t.endtime, t.entct, t.inact, t.inadur, t.inadist, t.smlct, t.smldur, t.smldist, t.larct, t.lardur, t.lardist, t.emptyct, t.emptydur 
FROM tmp t WHERE uid=x
ON DUPLICATE KEY UPDATE entct=t.entct, inact=t.inact, ...;
登录后复制

在此查询中,INSERT INTO 子句中命名的列将用于列分配默认值:

  • exp_id
  • 创建者
  • 位置
  • 动物
  • 开始时间
  • 结束时间

中命名的列SELECT 子句将用于指定更新值:

  • t.location
  • t.animal
  • t.starttime
  • t .endtime
  • t.entct
  • t.inact
  • t.inadur
  • t.inadist
  • t.smlct
  • t.smldur
  • t.smldist
  • t.larct
  • t.lar dur
  • t.lardist
  • t.emptyct
  • t.emptydur

列未包含在 ON DUPLICATE KEY UPDATE 子句中的将不会被更新。

以上是MySQL 如何处理 INSERT ... SELECT ... ON DUPLICATE KEY UPDATE 语法?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板