PHP获取MySql新增记录ID值的方法

今天发现用mysql_insert_id()获取到的新增记录的id不正确,

虽然发现源代码的事务写的有问题,但是最根本的原因是,我插入数据的id类型是bigint型 

获取MySql新增记录ID值的方法有

1.使用语句

1
mysql_query("select max(id) from user",$link);

2.使用函数msyql_insert_id();

(1)mysql版

1
int mysql_insert_id ([ resource $link_identifier = NULL ] )

返回在最后一次执行了 INSERT 查询后,由 AUTO_INCREMENT 定义的字段的值。

返回上一步 INSERT 操作产生的 ID。如果上一查询没有产生 AUTO_INCREMENT 的 ID,则 mysql_insert_id() 返回 0

但是当id 为bigint 型时 就不在起作用了

(2)mysqli版

1
mixed mysqli_insert_id ( mysqli $link )

可根据结果的大小返回一个int或者string

3.使用查询

1
msyql_query("select last_insert_id()");

last_insert_id() 是mysql 函数 

该方法解决了 mysql_insert_id () 中遇到的 bigint 型问题 

last_insert_id() 返回的是 AUTO_INCREMENT 的 ID。 

如果返回为0,查看表结构中,没有设置AUTO_INCREMENT ;或者是不是用了 insert delay 的功能(不会返回即时的返回id值)

4.PDO里的函数

1
public string PDO::lastInsertId ([ string $name = NULL ] )

 返回最后插入行的ID或序列值

  

 

 

posted @   慕尘  阅读(6844)  评论(0编辑  收藏  举报
(评论功能已被禁用)
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
点击右上角即可分享
微信分享提示