程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> 更多數據庫知識 >> 解析sql中得到剛剛插入的數據的id

解析sql中得到剛剛插入的數據的id

編輯:更多數據庫知識

LAST_INSERT_ID:
LAST_INSERT_ID 是與table無關的,如果向表a插入數據後,再向表b插入數據,LAST_INSERT_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返回一個列表。

可以用 SELECT last_insert_id();查詢LAST_INSERT_ID的值.
Important: If you insert multiple rows using a single INSERT statement, LAST_INSERT_ID() returns the value generated for the first inserted row only.
使用單INSERT語句插入多條記錄,  LAST_INSERT_ID只返回插入的第一條記錄產生的值. 比如

 mysql> INSERT INTO t VALUES (NULL, 'aaaa'), (NULL, 'bbbb'), (NULL, 'cccc');  
 mysql> SELECT * FROM t;  
 +----+------+  
 | id | name |  
 +----+------+  
 |  1 | Bob  |  
 |  2 | aaaa |  
 |  3 | bbbb |  
 |  4 | cccc |  
 +----+------+  
 mysql> SELECT LAST_INSERT_ID();  
 +------------------+  
 | LAST_INSERT_ID() |  
 +------------------+  
 |                2 |  
 +------------------+ 
ID 2 是在插入第一條記錄aaaa 時產生的.
select @@IDENTITY:
String sql="select @@IDENTITY";
@@identity是表示的是最近一次向具有identity屬性(即自增列)的表插入數據時對應的自增列的值,是系統定義的全局變量。一般系統 定義的全局變量都是以@@開頭,用戶自定義變量以@開頭。比如有個表A,它的自增列是id,當向A表插入一行數據後,如果插入數據後自增列的值自動增加至 101,則通過select @@identity得到的值就是101。使用@@identity的前提是在進行insert操作後,執行select @@identity的時候連接沒有關閉,否則得到的將是NULL值。

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