前言
最近一个同事问我,为什么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列上自动生成的第一个值。总结的这句话比翻译的那句话感觉顺口多了==
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
本文向大家介绍轻松掌握JavaScript状态模式,包括了轻松掌握JavaScript状态模式的使用技巧和注意事项,需要的朋友参考一下 状态模式 状态模式(State)允许一个对象在其内部状态改变的时候改变它的行为,对象看起来似乎修改了它的类。 状态模式的使用场景也特别明确,有如下两点: 1.一个对象的行为取决于它的状态,并且它必须在运行时刻根据状态改变它的行为。(有些对象通常会有好几个状态
本文向大家介绍轻松掌握Java享元模式,包括了轻松掌握Java享元模式的使用技巧和注意事项,需要的朋友参考一下 定义:它使用共享物件,用来尽可能减少内存使用量以及分享资讯给尽可能多的相似物件;它适合用于只是因重复而导致使用无法令人接受的大量内存的大量物件。 特点:大大减少对象的创建,降低系统的内存,使效率提高。 企业级开发及常用框架中的应用:数据库的连接池,String的常量缓存池 具体代码实例:
本文向大家介绍轻松掌握Java状态模式,包括了轻松掌握Java状态模式的使用技巧和注意事项,需要的朋友参考一下 定义:在状态模式(State Pattern)中,类的行为是基于它的状态改变的。 特点: 1、封装了转换规则。 2、枚举可能的状态,在枚举状态之前需要确定状态种类。 3、将所有与某个状态有关的行为放到一个类中,并且可以方便地增加新的状态,只需要改变对象状态即可改变对象的行为。 4、允许状
本文向大家介绍轻松掌握java组合模式,包括了轻松掌握java组合模式的使用技巧和注意事项,需要的朋友参考一下 组合模式,将对象组合成树形结构以表示“部分-整体”的层次结构,组合模式使得用户对单个对象和组合对象的使用具有一致性,组合模式可以让客户端像修改配置文件一样简单的完成本来需要流程控制语句来完成的功能。 特点:对于递归或者类似树形的分级数据结构,可以用最简单的方式进行处理。 企业级开发和常用
本文向大家介绍轻松掌握java外观模式,包括了轻松掌握java外观模式的使用技巧和注意事项,需要的朋友参考一下 定义:外观模式(Facade),为子系统中的一组接口提供一个一致的界面,定义一个高层接口,这个接口使得这一子系统更加容易使用 特点: (1)实现了子系统与客户端之间的松耦合关系。 (2)客户端屏蔽了子系统组件,减少了客户端所需处理的对象数目,并使得子系统使用起来更加容易。
本文向大家介绍轻松掌握Java单例模式,包括了轻松掌握Java单例模式的使用技巧和注意事项,需要的朋友参考一下 单例模式是23中设计模式中最简单的设计模式,在企业开发中也应用的特别多。单例模式的优点是:项目中有且仅有一个实例。 特点:构造器私有化,对象私有化,只提供一个对外访问的接口。 应用场景: 1、系统需要共享资源:比如日志系统,spring的资源管理器等 2、为了控制资源的使
本文向大家介绍轻松掌握JavaScript代理模式,包括了轻松掌握JavaScript代理模式的使用技巧和注意事项,需要的朋友参考一下 在面向对象设计中,有一个单一职责原则,指就一个类(对象、函数)而言,应该仅有一个引起它变化的原因。如果一个对象承担了过多的职责,就意味着它将变得巨大,引起它变化的原因就多,它把这些职责耦合到了一起,这种耦合会导致程序难于维护和重构。 这时候,我们可以把该对象(本
本文向大家介绍轻松掌握JavaScript策略模式,包括了轻松掌握JavaScript策略模式的使用技巧和注意事项,需要的朋友参考一下 定义:定义一系列的算法,把它们一个个封装成函数,也可把它们作为属性统一封装进一个对象,然后再定义一个方法,该方法可根据参数自动选择执行对应的算法。 一般用于在实现一个功能时,有很多个方案可选择的情况。 例子1:根据员工薪水salary、绩效等级S、A、B、C,