mysql 數據庫 如何獲取剛剛插入的自增長的id號

在MySQL中,使用auto_increment類型的id字段作爲表的主鍵,並用它作爲其他表的外鍵,形成“主從表結構”,這是數據庫設計中常見的用法。但是在具體生成id的時候,我們的操作順序一般是:先在主表中插入記錄,然後獲得自動生成的id,以它爲基礎插入從表的記錄。這裏面有個困難,就是插入主表記錄後,如何獲得它對應的id。通常的做法,是通過“select max(id) from tablename”的做法,但是顯然這種做法需要考慮併發的情況,需要在事務中對主表加以“X鎖“,待獲得max(id)的值以後,再解鎖。這種做法需要的步驟比較多,有些麻煩,而且併發性也不好。有沒有更簡單的做法呢?答案之一是通過select LAST_INSERT_ID()這個操作。乍一看,它和select max(id)很象,但實際上它是線程安全的。也就是說它是具體於數據庫連接的。下面通過實驗說明:  
  
  1、在連接1中向A表插入一條記錄,A表包含一個auto_increment類型的字段。  
  
  2、在連接2中向A表再插入一條記錄。  
  
  3、結果:在連接1中執行select LAST_INSERT_ID()得到的結果和連接2中執行select LAST_INSERT_ID()的結果是不同的;而在兩個連接中執行select max(id)的結果是相同的。  
  
  其實在MSSQL中SCOPE_IDENTITY()和IDENT_CURRENT()的區別和這裏是類似的。使用SCOPE_IDENTITY()可以獲得插入某個IDENTITY字段的當前會話的值,而使用IDENT_CURRENT()會獲得在某個IDENTITY字段上插入的最大值,而不區分不同的會話。  
  
  注:使用select last_insert_id()時要注意,當一次插入多條記錄時,只是獲得第一次插入的id值,務必注意!可以試試  
  
  insert into tb(c1,c2) values (c1value,c2value),(c1value1,c2value2)..。  
  
   
  
最後有個問題一直沒解決:  
  
使用select last_insert_id()時要注意,當一次插入多條記錄時,只是獲得第一次插入的id值,務必注意。  
注:在java中使用last_insert_id();是要在一插入後就使用,也就是不能新建立Connection
比如insert建了一個Connection,用last_insert_id()就要用同一個Connection,不能在兩條查詢語句(即“insert into。。。”和"select last_insert_id()")都使用getConn()創建新管道,正確的做法是insert語句getConn()創建了管道以後,"select last_insert_id()"就直接用全局變量的conn也就是創建好的同一管道查詢纔有效果,否則會返回0得不到新插入的自動增長列列號,切忌!!!!!!!!!
  
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章