MySQL获取刚插入的数据的自增长的id的值

MySQL数据库,主键自增的情况下要获取刚刚新增的那条数据的id,可以使用:

select last_insert_id();  

例如:student表:

idnameage
1小明10
2小花10

新增语句:insert into student(name,age) values ("小三","20");
这时如果使用select last_insert_id(); 是可以查出这条数据的id为3的。

但是我找到了一个这个语句不生效的情况:
我刚找到这个方法的时候想测试一下,我就写了一个新增语句,是这么写的:insert into student(id,name,age) values (3,"小三","20");
然后我再用select last_insert_id();发现结果出来是0,我觉得可能是我的新增语句里直接指定了主键的值,没有让MySQL为它自增出一个值所以这个语句不生效。

其实这个发现很扯,可以说基本没用,因为基本没有哪种业务场景是由代码去指定自增id的值的,如果真的能指定,那其实根本没有必要用这个语句再获取一遍id的值。但也权当一个发现记录在这里吧。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值