眾所周知,MySQL LAST_INSERT_ID() 函數(shù)返回最新生成的序列號(hào),但在多行插入的情況下,它將返回由最前面插入的行生成的序列號(hào)。
示例
mysql> Insert into Student(Name) values('Ram'),('Mohan'),('Aryan'); Query OK, 3 rows affected (0.03 sec) Records: 3 Duplicates: 0 Warnings: 0
登錄后復(fù)制
上面的查詢(xún)借助多行插入查詢(xún)?cè)?Student 表中插入三個(gè)值。可以借助以下查詢(xún)來(lái)檢查列“Id”的值 –
mysql> Select * from Student; +----+-------+ | Id | Name | +----+-------+ | 1 | Raman | | 2 | Rahul | | 3 | Ram | | 4 | Mohan | | 5 | Aryan | +----+-------+ 5 rows in set (0.00 sec)
登錄后復(fù)制
這意味著 Last_Insert_Id() 必須返回 5 作為輸出,但我們可以看到它返回值 3,如下 –
mysql> Select Last_Insert_Id(); +------------------+ | Last_Insert_Id() | +------------------+ | 3 | +------------------+ 1 row in set (0.00 sec)
登錄后復(fù)制
它返回值 3,因?yàn)?3 是上述多行插入查詢(xún)中最先插入的行的值。
以上就是在多行插入的情況下,對(duì) MySQL LAST_INSERT_ID() 函數(shù)的輸出有何影響?的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注www.92cms.cn其它相關(guān)文章!