轻松掌握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


相关推荐: Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出  Laravel如何使用集合(Collections)进行数据处理_Laravel Collection常用方法与技巧  香港服务器选型指南:免备案配置与高效建站方案解析  利用JavaScript实现拖拽改变元素大小  网站制作企业,网站的banner和导航栏是指什么?  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门  javascript日期怎么处理_如何格式化输出  如何正确下载安装西数主机建站助手?  新三国志曹操传主线渭水交兵攻略  如何在Ubuntu系统下快速搭建WordPress个人网站?  香港服务器建站指南:外贸独立站搭建与跨境电商配置流程  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】  网站制作价目表怎么做,珍爱网婚介费用多少?  Linux系统命令中screen命令详解  Java解压缩zip - 解压缩多个文件或文件夹实例  深圳防火门网站制作公司,深圳中天明防火门怎么编码?  微信小程序 配置文件详细介绍  昵图网官网入口 昵图网素材平台官方入口  Laravel怎么自定义错误页面_Laravel修改404和500页面模板  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  如何用wdcp快速搭建高效网站?  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  Swift中swift中的switch 语句  Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】  三星网站视频制作教程下载,三星w23网页如何全屏?  Laravel如何记录自定义日志?(Log频道配置)  高端建站三要素:定制模板、企业官网与响应式设计优化  Python自动化办公教程_ExcelWordPDF批量处理案例  PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  清除minerd进程的简单方法  深圳网站制作平台,深圳市做网站好的公司有哪些?  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  javascript读取文本节点方法小结  Python函数文档自动校验_规范解析【教程】  网站制作壁纸教程视频,电脑壁纸网站?  浅述节点的创建及常见功能的实现  如何快速生成可下载的建站源码工具?  Python文本处理实践_日志清洗解析【指导】  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  如何彻底删除建站之星生成的Banner?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤