首页 > 数据库 > mysql教程 > 在多行插入的情况下,对 MySQL LAST_INSERT_ID() 函数的输出有何影响?

在多行插入的情况下,对 MySQL LAST_INSERT_ID() 函数的输出有何影响?

WBOY
发布: 2023-09-02 13:13:02
转载
817 人浏览过

在多行插入的情况下,对 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 是上述多行插入查询中最先插入的行的值。

以上是在多行插入的情况下,对 MySQL LAST_INSERT_ID() 函数的输出有何影响?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:tutorialspoint.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板