MySQL是一個(gè)廣泛使用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),它提供了許多有用的特性,包括INSERT RETURNING語句,可以在插入新記錄時(shí)返回生成的主鍵ID。
INSERT INTO `users` (`name`, `email`) VALUES ('Johnny', 'johnny@example.com'); SELECT LAST_INSERT_ID();
在這個(gè)例子中,我們向名為users的表中插入了一條新記錄,然后使用LAST_INSERT_ID函數(shù)返回新生成的主鍵ID。這是一個(gè)非常有用的功能,特別是在需要立即使用新生成的ID時(shí)。
如果您使用的是InnoDB引擎,并且自動提交被啟用,那么您可以使用以下代碼來返回最新插入的主鍵ID:
INSERT INTO `users` (`name`, `email`) VALUES ('Johnny', 'johnny@example.com'); SELECT @@IDENTITY;
要注意的是,如果INSERT語句中包含多個(gè)值,則返回的ID將是最后一個(gè)插入的記錄的ID。
最后,雖然INSERT RETURNING語句非常方便,但是在大型數(shù)據(jù)庫中,它可能會降低性能。如果您需要高性能,建議將其用于小型數(shù)據(jù)庫或非常需要它的場景。