首页 >数据库 >mysql教程 >如何在使用 ON DUPLICATE KEY 的 MySQL INSERT/UPDATE 后获取行 ID?

如何在使用 ON DUPLICATE KEY 的 MySQL INSERT/UPDATE 后获取行 ID?

Barbara Streisand
Barbara Streisand原创
2024-12-05 08:51:13570浏览

How to Get the Row ID After a MySQL INSERT/UPDATE with ON DUPLICATE KEY?

如何在使用 MySQL ON DUPLICATE KEY 进行插入/更新后检索行的 ID

使用 ON DUPLICATE KEY 插入或更新数据MySQL 中的子句可以是处理重复键错误的便捷方法。但是,在操作后获取受影响行的 ID 可能具有挑战性。

一个常见的假设是 LAST_INSERT_ID() 函数仅返回新插入的行的 ID。但是,在 ON DUPLICATE KEY 场景中,如果修改了行,它也可能返回更新的 ID。

解决方案:LAST_INSERT_ID(expr)

要使 LAST_INSERT_ID () 对于插入和更新都有意义,MySQL 提供了以下内容解决方法:

INSERT INTO table (a,b,c) VALUES (1,2,3)
ON DUPLICATE KEY UPDATE>

在此示例中,假定 id 列是 AUTO_INCREMENT 主键。通过在更新时将 LAST_INSERT_ID(id) 分配给 id 列,该函数将返回更新后的 ID。

检索上次插入/更新 ID

解决方法后地方,您可以使用 LAST_INSERT_ID() 函数来检索插入的行的 ID 或更新:


此方法允许您检索受 INSERT/UPDATE 操作影响的行的 ID,而无需运行单独的查询来获取它。

以上是如何在使用 ON DUPLICATE KEY 的 MySQL INSERT/UPDATE 后获取行 ID?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn