首页 > 数据库 > mysql教程 > 如何使用'INSERT INTO ... SELECT ...”正确指定 MySQL 的'ON DUPLICATE KEY UPDATE”子句中的列?

如何使用'INSERT INTO ... SELECT ...”正确指定 MySQL 的'ON DUPLICATE KEY UPDATE”子句中的列?

Linda Hamilton
发布: 2024-12-03 11:26:16
原创
425 人浏览过

How to Correctly Specify Columns in MySQL's `ON DUPLICATE KEY UPDATE` Clause with `INSERT INTO ... SELECT ...`?

解析“INSERT INTO ... SELECT FROM ... ON DUPLICATE KEY UPDATE”中的列更新语法

此查询将数据从 tmp 插入到 lee 表中表,如果发生唯一键冲突则更新现有行。但是,ON DUPLICATE KEY UPDATE 子句的语法似乎不清楚。

解决方案

MySQL 假设 ON DUPLICATE KEY UPDATE 后等式的左侧引用了 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, ...
登录后复制

在此查询中,ON DUPLICATE KEY UPDATE 子句的左侧与 INSERT INTO 子句中指定的列匹配。等号之前的列代表 leo 表中的列,等号之后的列代表要从 SELECT 子句更新的值。

以上是如何使用'INSERT INTO ... SELECT ...”正确指定 MySQL 的'ON DUPLICATE KEY UPDATE”子句中的列?的详细内容。更多信息请关注PHP中文网其他相关文章!

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