向mysql 插入數(shù)據(jù)時 很多時候 我們想知道剛剛插入數(shù)據(jù)的id 這對我們很有用 下面我說出常用的三種方法并一一分析其利與弊。
一 用以下語句:
mysql_query("select max(id) from t1",$link);
使用這種方法時 我們得到得是 id最大的值 的確時最后一個 但當(dāng)多鏈接線程時這個最大的id并不一定是 我們插入的所以這個不利用域線程。
二 用以下函數(shù):
當(dāng)系統(tǒng)執(zhí)行完INSERT后,再執(zhí)行SELECT時,可能已經(jīng)被分發(fā)到了不同的后端服務(wù)器,如果你使用的編程語言是PHP的話,此時應(yīng)該通過 mysql_insert_id()來得到最新插入的id,每次INSERT結(jié)束后,其實對應(yīng)的autoincrement值就已經(jīng)計算好返回給PHP 了,你無需再發(fā)出一次獨立的查詢,直接用mysql_insert_id()就可以了這個函數(shù)很好用 當(dāng)我們插入一條語句時 它自動返回了 最后的id值并且此函數(shù) 僅對當(dāng)前鏈接有用 也就是說 它是多用戶安全型的所以我們經(jīng)常用此函數(shù);
但此函數(shù)有一個問題 就是 當(dāng)id 為bigint 型時 就不在起作用了 所以 現(xiàn)在 正在用此函數(shù)的請小心了不過 我們平時很少遇到這樣的問題,所以可以不用管它。
三:用一下查詢
msyql_query("select last_insert_id()");
last_insert_id() 是mysql 一個函數(shù) 也是 對當(dāng)前鏈接起效此用法 解決了 mysql_insert_id () 中遇到的 bigint 型問題。
總結(jié): 根據(jù)以上分析 第一種方法 盡量少用 多用第二種方法 當(dāng)遇到特殊情況時 可以考慮用第三種方法
以上這篇php獲得剛插入數(shù)據(jù)的id 的幾種方法總結(jié)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 解析sql中得到剛剛插入的數(shù)據(jù)的id
- ThinkPHP寫數(shù)組插入與獲取最新插入數(shù)據(jù)ID實例
- php插入mysql數(shù)據(jù)返回id的方法
- THINKPHP在添加數(shù)據(jù)的時候獲取主鍵id的值方法
- PHP用mysql_insert_id()函數(shù)獲得剛插入數(shù)據(jù)或當(dāng)前發(fā)布文章的ID
- php 生成唯一id的幾種解決方法