如何在使用 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中文网其他相关文章!