安全執行緒地擷取插入mysql的條目的id

來源:互聯網
上載者:User

標籤:style   color   使用   資料   sp   c   資料庫   sql   mysql   

在往mysql中插入條目時有時會希望能得到該插入條目的id,一種方式是再執行一個select語句條件為max(id)來擷取,但這種形式在並發環境裡並不是安全執行緒的,因為在你完成插入到再執行一個select擷取最大id之間可能已經有另一個條目被插入。

一種安全執行緒的解決方式是採用select LAST_INSERT_ID()這個語句,它返回本次連結(每個資料庫連結由一個線程承擔)中第一次插入的條目的id

eg.

(1)、在串連1中向A表插入一條記錄,A表包含一個auto_increment類型的id。
 
(2)、在串連2中向A表再插入一條記錄。
 
(3)、結果:在串連1中執行select LAST_INSERT_ID()得到的結果和串連2中執行select LAST_INSERT_ID()的結果是不同的;而在兩個串連中執行select max(id)的結果是相同的。

此外,使用select last_insert_id()時要注意,當一次插入多條記錄時,只是獲得第一次插入的id值,務必注意!

 

安全執行緒地擷取插入mysql的條目的id

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.