在多行插入的情況下,MySQL LAST_INSERT_ID() 函式的輸出會受到什麼影響?
眾所周知,MySQL LAST_INSERT_ID() 函式返回最新生成的序列號,但在多行插入的情況下,它將返回 *最先* 插入行的序列號。
示例
mysql> Insert into Student(Name) values('Ram'),('Mohan'),('Aryan');
Query OK, 3 rows affected (0.03 sec)
Records: 3 Duplicates: 0 Warnings: 0上面的查詢使用多行插入查詢在 Student 表中插入三個值。“Id” 列的值可以使用以下查詢進行檢查:
mysql> Select * from Student; +----+-------+ | Id | Name | +----+-------+ | 1 | Raman | | 2 | Rahul | | 3 | Ram | | 4 | Mohan | | 5 | Aryan | +----+-------+ 5 rows in set (0.00 sec)
這意味著 Last_Insert_Id() 應該返回 5,但正如我們所看到的,它返回的值是 3:
mysql> Select Last_Insert_Id(); +------------------+ | Last_Insert_Id() | +------------------+ | 3 | +------------------+ 1 row in set (0.00 sec)
它返回 3,因為 3 是上述多行插入查詢中 *最先* 插入行的值。
廣告
資料結構
網路
關係資料庫管理系統 (RDBMS)
作業系統
Java
iOS
HTML
CSS
Android
Python
C 語言程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP