MYSQL 小技巧 — LAST_INSERT_ID

來源:互聯網
上載者:User

其實,這兩個是有區別的,LAST_INSERT_ID() 能返回 bigint 值的id。而,mysql_insert_id 返回的是 int 。如果你
的id 是 unsigned int,或者 bigint 的 。那麼,可能是返回的是錯誤的。而要用 LAST_INSERT_ID() 代替。

還有些朋友,返回的都是 0,不知道怎麼回事,其實 LAST_INSERT_ID() 返回的是 AUTO_INCREMENT 的 ID。
如果,表結構中,沒有設定,AUTO_INCREMENT 那麼也無法返回。

還有些人,還是返回為 0. 那麼你就要檢查一下,是不是 用了 insert delay 的功能。這種情況下,是不會返回即時的返回id值的。

很多人喜歡用 select max(id) ... 來替換這個last_insert_id, 實際上, select max(id) 是非安全執行緒的,很有可能,
其他線程插入了新的資料,你就查不到你上次插入的 ID 了。而last_insert_id 是 和 一個mysql connect 相對應的,也就是
和你的當前線程相對應的,不會受其他線程的幹擾。如果你的資料庫發生了一些奇怪的錯誤,比如,本來是要更新A 資料的資訊的,
結果 B 資料被更新了,而且是有時候正確,有時候不正確,人多的時候會非常的不正確。就要看看是不是 用了 select max(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.