在多行插入的情况下,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 是使用上述多行插入查询插入的首行的值。
广告