上一篇:查找数据库的重复记录(附SQL语句)
下一篇:网页防复制(附代码)
MySQL插入新记录后获取插入数据的id值
米娅 2013年6月11日 14:48:44

在网上找到的:

在MySQL中,使用auto_increment类型的id字段作为表的主键。通常的做法,是通过“select max(id) from tablename”的做法,但是显然这种做法需要考虑并发的情况,需要在事务中对主表以“X锁“,待获得max(id)的值以后,再解锁。这种做法需要的步骤比较多,有些麻烦,而且并发性也不好。有没有更简单的做法呢?答案之一是通过select LAST_INSERT_ID()这个操作。乍一看,它和select max(id)很象,但实际上它是线程安全的。也就是说它是基于数据库连接的,基于数据库连接是什么意义呢?举例说明:

(1)、在连接1中向A表插入一条记录,A表包含一个auto_increment类型的id。

(2)、在连接2中向A表再插入一条记录。

(3)、结果:在连接1中执行select LAST_INSERT_ID()得到的结果和连接2中执行select LAST_INSERT_ID()的结果是不同的;而在两个连接中执行select max(id)的结果是相同的。

注:使用select last_insert_id()时要注意,当一次插入多条记录(批量插入)时,只是获得第一次插入的id值,务必注意!

LAST_INSERT_ID() 自动返回最后一个INSERT或 UPDATE 查询中 AUTO_INCREMENT列设置的第一个表发生的值。

一般情况下获取刚插入的数据的id,使用select max(id) from table 是可以的。但在多线程情况下,就不行了。在多用户交替插入数据的情况下max(id)显然不能用。这就该使用LAST_INSERT_ID了,因为LAST_INSERT_ID是基于Connection 的,只要每个线程都使用独立的Connection对象,LAST_INSERT_ID函数将返回该Connection对AUTO_INCREMENT 列最新的insert or update操作生成的第一个record的ID。LAST_INSERT_ID是基于单个connection的, 不可能被其它的客户端连接改变。


共1页
相关链接
1. Drupal 7.23: PDOException: SQLSTATE[HY000]: General error: 2006 MySQL server has gone away:
2. 从Excel导入数据到MySQL出现中文乱码(已解决)
3. 将Excel数据保存到MySQL数据库及PHP读Excel数据(附代码)
4. 如何修改MySQL表和列的COMMENT
5. 用MySQL的触发、存储程序、函数改善网页速度(附运行于phpMyAdmin的例子代码)
6. 如何备份、恢复MySQL数据库
7. MySQL的数据库备份问题
8. MySQL数据库的汉字乱码问题