当前位置: 首页 > 图文教程 > 网络编程 > PHP > MYSQL 小技巧 -- LAST_INSERT_ID

PHP
Windows下PHP+MySQL+IIS安全平台搭建
e2php搭建Windows下Apache+PHP+MySQL环境
网站图片防被盗的方法汇总
PHP简单学习,保证入门学会
19个PHP模板引擎介绍
PHP菜鸟你是吗?
PHP在国内的应用探讨与分析
PHP+MYSQL网站开发基础知识
PHP解决乱码问题的三种办法
你可能不知道的关于PHP的10件事
PHP基础教程(1):认识PHP
PHP基础教程(2):PHP安装
PHP基础教程(3):PHP语法
PHP基础教程(4):PHP变量
PHP基础教程(5):PHP字符串
PHP基础教程(6):PHP运算符
PHP基础教程(7):PHP If...Else语句
PHP基础教程(8):PHP Switch语句
PHP基础教程(9):PHP数组
PHP基础教程(10):PHP循环

PHP 中的 MYSQL 小技巧 -- LAST_INSERT_ID


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-01-10   浏览: 143 ::
收藏到网摘: n/a

用PHP调用mysql , 内置的LAST_INSERT_ID() 这个函数可能没有什么人用,用的最多的还是 mysql_insert_id() 其实,这两个是有区别的,LAST_INSERT_ID() 能返回 bigint 值的id。而,mysql_insert_id 返回的是 int 。如果你
的id 是 unsigned int,或者 bigint 的 。那么,可能是返回的是错误的。而要用 LAST_INSERT_ID() 代替。
还有些朋友,返回的都是 0,不知道怎么回事,其实 LAST_INSERT_ID() 返回的是 AUTO_INCREMENT 的 ID。
如果,表结构中,没有设置,AUTO_INCREMENT 那么也无法返回。
还有些人,还是返回为 0. 那么你就要检查一下,是不是 用了 insert delay 的功能。这种情况下,是不会返回即时的返回id值的。
很多人喜欢用 select max(id) ... 来替换这个last_insert_id, 实际上, select max(id) 是非线程安全的,很有可能,
其他线程插入了新的数据,你就查不到你上次插入的 ID 了。而last_insert_id 是 和 一个mysql connect 相对应的,也就是
和你的当前线程相对应的,不会受其他线程的干扰。如果你的数据库发生了一些奇怪的错误,比如,本来是要更新A 数据的信息的,
结果 B 数据被更新了,而且是有时候正确,有时候不正确,人多的时候会非常的不正确。就要看看是不是 用了 select max(id)