一、使用語句:
復制代碼 代碼如下:mysql_query("select max(id) from t1",$link);
使用此方法得到的是 id最大的值,確為最後一個值,但當多鏈接線程時,這個最大的id並不一定是我們插入數據的自增id值,因此不適用於多線程。
二,使用函數:msyql_insert_id();
在PHP中,經常需要把插入數據庫中的id值取出來,而正好有這麼一個函數:
復制代碼 代碼如下:
<?php
//執行插入數據庫的語句
//……
$getID=mysql_insert_id();//$getID即為最後一條記錄的ID
//此函數的使用條件:
//1.假設字段名稱為recordID
//2.字段屬性須設為:auto_increment
//3.添加數據後使用
//$newID = mysql_insert_id();
//得到ID值
?>
PHP 函數 mysql_insert_id() 是返回在最後一次執行了 INSERT 查詢後,由 AUTO_INCREMENT 定義的字段的值。
當系統執行完INSERT後,再執行SELECT時,可能已經被分發到了不同的後端服務器,如果使用php編程,此時應該通過 mysql_insert_id()來得到最新插入的id,每次INSERT結束後,其實對應的autoincrement值就已經計算好返回給PHP 了,你無需再發出一次獨立的查詢,直接用mysql_insert_id()即可。
當插入一條語句時,它自動返回最後的id(mysql自增值)。
並且此函數僅對當前鏈接有用,即它是多用戶安全型的。
建議使用此函數;
問題:當id 為bigint 型時 就不在起作用了。
三、使用查詢
復制代碼 代碼如下:msyql_query("select last_insert_id()");
last_insert_id() 是mysql 一個函數 也是 對當前鏈接起效
此用法 解決了 mysql_insert_id () 中遇到的 bigint 型問題
總結:
推薦使用方法二,特殊情況下,可以考慮方法三。