【转载】在mysql中获取insert插入数据的id的方法SELECT LAST_INSERT_ID();

SELECT LAST_INSERT_ID();

我们在写数据库程序的时候,经常会需要获取某个表中的最大序号数,或者刚插入的数据的ID值。
一般情况下获取刚插入的数据的id,使用select max(id) from table 是可以的。
但在多线程,高并发的情况下,就不行了。
开始的时候我想的是使用mysql_insert_id(),不知道会不会在并发的时候产生影响,查询了下手册,也是才发现,是根据connection来的,不同用户间不会产生影响。所以也不用去想先把表锁起来,插入取得ID值后再解锁。直接正常插入,然后取值,即可。

int mysql_insert_id ([ resource $link_identifier ] )

mysql_insert_id()返回给定的 link_identifier中上一步 INSERT 查询中产生的 AUTO_INCREMENT 的 ID 号。如果没有指定 link_identifier,则使用上一个打开的连接。

如果上一查询没有产生 AUTO_INCREMENT 的值,则 mysql_insert_id()返回 0。如果需要保存该值以后使用,要确保在产生了值的查询之后立即调用 mysql_insert_id()。
warning: mysql_insert_id() 将 MySQL 内部的 C API 函数 mysql_insert_id()的返回值转换成 long(PHP 中命名为 int)。如果 AUTO_INCREMENT 的列的类型是 BIGINT,则 mysql_insert_id()返回的值将不正确。可以在 SQL 查询中用 MySQL 内部的 SQL 函数 LAST_INSERT_ID() 来替代。

此外,还可以通过QUERY两个SQL语句来执行:

 
1 --1 ,查询 LAST_INSERT_ID()
2 mysql> select LAST_INSERT_ID();
3 +------------------+
4 | LAST_INSERT_ID() |
5 +------------------+
6 |                4 |
7 +------------------+
8 1 row in set (0.00 sec)
9   
10 --2 查询 @@IDENTITY
11 mysql> select @@IDENTITY;
12 +------------+
13 | @@IDENTITY |
14 +------------+
15 |          4 |
16 +------------+
17 1 row in set (0.00 sec)

LAST_INSERT_ID 是与table无关的,如果向表a插入数据后,再向表b插入数据,LAST_INSERT_ID会改变。如果后边需要a表的ID值,需要先手动存起来。
LAST_INSERT_ID是基于Connection的,只要每个线程都使用独立的Connection对象,LAST_INSERT_ID函数将返回该Connection对AUTO_INCREMENT列最新的insert or update*作生成的第一个record的ID。这个值不能被其它客户端(Connection)影响,保证了你能够找回自己的 ID 而不用担心其它客户端的活动,而且不需要加锁。使用单INSERT语句插入多条记录, LAST_INSERT_ID返回受影响的第一行的ID值。

 
1 --最大ID值已经为4,这时候用一条sql插入两条数据。然后获取LAST_INSERT_ID().
2 insert test(test_name,test_address) values('111','222'),('1111','2222');
3 mysql> select LAST_INSERT_ID();
4 +------------------+
5 | LAST_INSERT_ID() |
6 +------------------+
7 |                5 |
8 +------------------+

@@identity是表示的是最近一次向具有identity属性(即自增列)的表插入数据时对应的自增列的值,是系统定义的全局变量。一般系统定义的全局变量都是以@@开头,用户自定义变量以@开头。比如有个表A,它的自增列是id,当向A表插入一行数据后,如果插入数据后自增列的值自动增加至101,则通过select @@identity得到的值就是101。使用@@identity的前提是在进行insert操作后,执行select @@identity的时候连接没有关闭,否则得到的将是NULL值。

你可能感兴趣的:(mysql)