1. 程式人生 > >獲取mysql 自增id 和mysql 下一個自增id的方法

獲取mysql 自增id 和mysql 下一個自增id的方法

mysql獲取表中自增id的方法:


1. 使用 select MAX(id) from tablename; 獲取的是表中最大的id;順序執行  insert ---> delete 插入的資料----> select MAX(id) from tablename; 獲取到的是 insert 之前的最大id; 


2. SELECT LAST_INSERT_ID(); 獲取到的是最後一次insert 自增表資料的id;
LAST_INSERT_ID 是與table無關的,如果向表a插入資料後,再向表b插入資料,LAST_INSERT_ID 現實的是b表中插入資料的id。 
 
在多使用者交替插入資料的情況下max(id)顯然不能用。這時就該使用LAST_INSERT_ID了,
LAST_INSERT_ID是基於Connection的
,只要每個執行緒都使用獨立的 Connection物件,LAST_INSERT_ID函式將返回該Connection對AUTO_INCREMENT列最新的insert or update 操作生成的第一個record的ID。這個值不能被其它客戶端(Connection)影響,保證了你能夠找回自己的 ID 而不用擔心其它客戶端的活動,而且不需要加鎖。使用單INSERT語句插入多條記錄, LAST_INSERT_ID返回一個列表。




3. @@IDENTITY 和 SCOPE_IDENTITY 可以返回當前會話中的所有表中生成的最後一個標識值。但是,SCOPE_IDENTITY 只在當前作用域內返回值,而 @@IDENTITY 不限於特定的作用域。
@@identity 是表示的是最近一次向具有identity屬性(即自增列)的表插入資料時對應的自增列的值,是系統定義的全域性變數。一般系統定義的全域性變數都是以@@開頭,使用者自定義變數以@開頭。 
 
比如有個表A,它的自增列是id,當向A表插入一行資料後,如果插入資料後自增列的值自動增加至101,則通過select @@identity得到的值就是101。使用@@identity的前提是在進行insert操作後,執行select @@identity的時候連線沒有關閉,否則得到的將是NULL值。 
 
4. SHOW TABLE STATUS; 
 
得出的結果裡邊對應表名記錄中有個Auto_increment欄位,裡邊有下一個自增ID的數值就是當前該表的最大自增ID. 


 獲取下一個自增id

AUTO_INCREMENT FROM information_schema.TABLES WHERE TABLE_SCHEMA = dbName AND TABLE_NAME = tblName;



例如:
SELECT auto_increment FROM information_schema.`TABLES` WHERE TABLE_SCHEMA='my_db_name' AND TABLE_NAME='my_table_name';
該方法獲取指定庫中指定自增主鍵表中下一個自增值時的id;