程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP獲取MySql新增記錄ID值的3種方法

PHP獲取MySql新增記錄ID值的3種方法

編輯:PHP綜合

一、使用語句:
 
復制代碼 代碼如下: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 型問題
總結:
推薦使用方法二,特殊情況下,可以考慮方法三。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved