轻松掌握MySQL函数中的last_insert_id()

发布时间 - 2026-01-10 21:50:06    点击率:

前言

最近一个同事问我,为什么last_insert_id()得到的结果与预期的不一样呢,于是我就认真的去研究的一下这个参数,下面是关于last_insert_id()的详细介绍,一起来学习学习吧。

首先,举个例子

wing@3306>show create table tt;
+-------+-----------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                           |
+-------+-----------------------------------------------------------------------------------------------------------------------+
| tt | CREATE TABLE `tt` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-------+-----------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
# 没有指定值的时候,last_insert_id()符合预期希望
wing@3306>insert into tt values();
Query OK, 1 row affected (0.00 sec)
wing@3306>select last_insert_id();
+------------------+
| last_insert_id() |
+------------------+
|    1 |
+------------------+
1 row in set (0.00 sec)
wing@3306>insert into tt values();
Query OK, 1 row affected (0.00 sec)
wing@3306>select last_insert_id();
+------------------+
| last_insert_id() |
+------------------+
|    2 |
+------------------+
1 row in set (0.00 sec)
# what?不是应该是5么,为什么是第一个插入的值3?last_insert_id开始有一点不符合预期了。。
wing@3306>insert into tt values(),(),();
Query OK, 3 rows affected (0.01 sec)
Records: 3 Duplicates: 0 Warnings: 0
wing@3306>select last_insert_id();
+------------------+
| last_insert_id() |
+------------------+
|    3 |
+------------------+
1 row in set (0.00 sec)
wing@3306>insert into tt values(),(),();
Query OK, 3 rows affected (0.01 sec)
Records: 3 Duplicates: 0 Warnings: 0
wing@3306>select last_insert_id();
+------------------+
| last_insert_id() |
+------------------+
|    6 |
+------------------+
1 row in set (0.00 sec)
# 纳尼?按照预期不是10么?为什么还是之前的6?last_insert_id()我不懂你啊。。
wing@3306>insert into tt values(10);
Query OK, 1 row affected (0.01 sec)
wing@3306>select last_insert_id();
+------------------+
| last_insert_id() |
+------------------+
|    6 |
+------------------+
1 row in set (0.00 sec)

其次,研究一下

查阅MySQL官方文档,真的太重要了。。。

官方出处:http://dev.mysql.com/doc/refman/5.6/en/information-functions.html#function_last-insert-id

官方文档原话:

With no argument, LAST_INSERT_ID() returns a 64-bit value representing the first automatically generated value successfully inserted for an AUTO_INCREMENT column as a result of the most recently executed INSERT statement.

翻译:

没有参数的last_insert_id()返回的是最近一次针对autoincrement列执行的INSERT语句的第一个自动生成的值。

官方文档原话:

If you insert multiple rows using a single INSERT statement, LAST_INSERT_ID() returns the value generated for the first inserted row only. The reason for this is to make it possible to reproduce easily the same INSERT statement against some other server.

翻译:

如果你在单条INSERT语句中插入多个值,那么last_insert_id()返回的是该INSERT语句第一个自动生成的值。

然后,剖析一下

请认真阅读上述翻译中的黑色字体,牢记last_insert_id()的约束。

为什么插入指定的值,last_insert_id()就失效了呢?

官方文档明明说了,是自动生成的值啊,不是你指定的值啊,是由autoincremnt计数器自己生成的才能被last_insert_id()追踪到哇。。

为什么多值插入的时候,显示的是第一条插入值啊,last不是最后一个值的意思么啊啊啊。。

官方文档明明说了,是最近一次的INSERT语句**自动生成的第一个值**哇哇哇。。

总结

记住last_insert_id()的约束。最近一次INSERT语句在autpincrement列上自动生成的第一个值。总结的这句话比翻译的那句话感觉顺口多了==

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。


# mysql  # last  # insert  # id  # sql  # Mysql中LAST_INSERT_ID()的函数使用详解  # MySQL中LAST_INSERT_ID()函数的实现  # 第一个  # 的是  # 自动生成  # 文档  # 说了  # 我就  # 好了  # 多个  # 是由  # 你在  # 问我  # 这句话  # 详细介绍  # 不符合  # 这篇文章  # 要了  # 第一条  # 你啊  # 太重  # 啊啊啊 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 网站建设保证美观性,需要考虑的几点问题!  Windows家庭版如何开启组策略(gpedit.msc)?(安装方法)  香港服务器租用费用高吗?如何避免常见误区?  Laravel怎么使用artisan命令缓存配置和视图  Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制  Java解压缩zip - 解压缩多个文件或文件夹实例  Python企业级消息系统教程_KafkaRabbitMQ高并发应用  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  Laravel如何自定义错误页面(404, 500)?(代码示例)  如何在阿里云ECS服务器部署织梦CMS网站?  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  如何为不同团队 ID 动态生成多个非值班状态按钮  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  JS中页面与页面之间超链接跳转中文乱码问题的解决办法  Laravel如何使用withoutEvents方法临时禁用模型事件  如何在新浪SAE免费搭建个人博客?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  详解vue.js组件化开发实践  Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  实例解析angularjs的filter过滤器  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程  Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】  如何在景安云服务器上绑定域名并配置虚拟主机?  Laravel如何实现API版本控制_Laravel API版本化路由设计策略  iOS UIView常见属性方法小结  JavaScript如何实现错误处理_try...catch如何捕获异常?  Laravel用户密码怎么加密_Laravel Hash门面使用教程  宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法  香港服务器选型指南:免备案配置与高效建站方案解析  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  历史网站制作软件,华为如何找回被删除的网站?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  利用 Google AI 进行 YouTube 视频 SEO 描述优化  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  如何获取上海专业网站定制建站电话?  浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】  重庆市网站制作公司,重庆招聘网站哪个好?  JS去除重复并统计数量的实现方法  WordPress 子目录安装中正确处理脚本路径的完整指南  如何在阿里云完成域名注册与建站?  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  七夕网站制作视频,七夕大促活动怎么报名?  标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析  如何快速搭建二级域名独立网站?