PHP返回insert操作产生的id
但是有一点,如果在INSERT语句里面明确指出了具有AUTO_INCREMENT属性的ID列的值,那么函数将返回0,因为该ID值是由用户指定的,不是由数据库自动产生的。
PHP手册对该函数的描述如下:
mysql_insert_id()
mysql_insert_id() 函数返回上一步 INSERT 操作产生的 ID。如果上一查询没有产生 AUTO_INCREMENT 的 ID,则 mysql_insert_id() 返回 0。
语法:mysql_insert_id(connection)
参数connection,可选。规定 MySQL 连接。如果未规定,则使用上一个连接。
mysql_insert_id() 返回给定的 connection 中上一步 INSERT 查询中产生的 AUTO_INCREMENT 的 ID 号。如果没有指定 connection ,则使用上一个打开的连接。
如果需要保存该值以后使用,要确保在产生了值的查询之后立即调用 mysql_insert_id()。
mysql_insert_id() 返回给定的 link_identifier 中上一步 INSERT 查询中产生的 AUTO_INCREMENT 的 ID 号。如果没有指定 link_identifier,则使用上一个打开的连接。如果上一查询没有产生 AUTO_INCREMENT 的值,则 mysql_insert_id() 返回 0。如果需要保存该值以后使用,要确保在产生了值的查询之后立即调用 mysql_insert_id()。
LAST_INSERT_ID()
MySQL也提供了这么一个同样功能的API,它总是保存着最新产生的AUTO_INCREMENT值,并且不会在查询语句之间被重置,也就是说,在执行INSERT操作后,执行SELECT、UPDATE、DELETE语句都不会影响该API的返回值。
可以用 SELECT LAST_INSERT_ID(); 来查询LAST_INSERT_ID() 的返回值。
使用单条INSERT语句插入多条记录,,LAST_INSERT_ID() 只返回插入的第一条记录产生的AUTO_INCREMENT值。
推荐阅读
-
array_values()在php中返回数组的操作实例
-
php插入mysql数据返回id的方法
-
Mybatis批量插入返回插入成功后的主键id操作
-
PHP 使用 POD 访问mysql数据库,怎么返回上一个插入记录的自增编号ID
-
PHP返回insert操作产生的id
-
PHP返回insert操作产生的id_PHP教程
-
PHP 使用 POD 访问mysql数据库,如何返回上一个插入记录的自增编号ID
-
史上产生位数最短的随机唯一ID php函数
-
PHP返回insert操作产生的id
-
Laravel之DB类操作数据库(创建表、添加字段、创建控制器、添加数据、修改数据、删除数据、显示查询数据、返回ID的方法getId)