数据库之获取最后一个自动生成的ID值的函数

    last_insert_id()函数自动返回最后一个insert或update为auto_increment列设置的第一个发生的值.该函数在你创建完表后使用插入语句insert一条记录一条记录进行插入时没有问题,但是当你使用insert语句同时插入多条记录时会出现与你理解上的不同,下面我们通过代码来讲解:

mysql> create table one(
    -> Id int auto_increment not null primary key,
    -> name varchar(30)
    -> );
Query OK, 0 rows affected (0.03 sec)

mysql> insert into one values(null, 'kevin'),(null, 'michal'),(null,'nick');
Query OK, 3 rows affected (0.08 sec)
Records: 3  Duplicates: 0  Warnings: 0

mysql> select * from one;
+----+--------+
| Id | name   |
+----+--------+
|  1 | kevin  |
|  2 | michal |
|  3 | nick   |
+----+--------+
3 rows in set (0.01 sec)

mysql> select last_insert_id();
+------------------+
| last_insert_id() |
+------------------+
|                1 |
+------------------+
1 row in set (0.00 sec)

你最后会疑问,你明明插入了三条记录,可为什么最后返回的id值为1.

这是因为当使用一条insert语句插入多个行时,last_insert_id()只返回插入的第一行数据时产生的值.这里为第一条记录.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值