mysql自增id获取
Posted Jachin的博客
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql自增id获取相关的知识,希望对你有一定的参考价值。
- 使用max函数:select max(id) from tablename
- 优点:使用方便快捷。
- 缺点:获取的不是真正的自增id,是表中最大的Id,如果有删除数据的话,那么该值和自增id相差比较大。如果有连表数据,有可能导致数据错乱。
- 使用LAST_INSERT_ID函数:select LAST_INSERT_ID()
- 优点:获取到的是真正的自增id。
- 缺点:该函数是与table无关的,永远保留最新插入的自增列的id。如果多客户端操作,而且不能保证原子性,这个值可能会出现错误。所以需要在插入之后调用。
- 使用@@IDENTITY变量:select @@IDENTITY
- 此方法和LAST_INSERT_ID()功能差不多,优缺点也一致。需要在插入后调用。
- 使用mysql查询函数:SHOW TABLE STATUS;
- 优点:能够准确的查到自增id。而且可以在语句后面加上where语句或者like语句来过滤。
- 缺点:该语句返回的是一个记录集,不能单独的返回自增值。所以需要额外的操作来获取。
- 使用自定义查询方法:mysql表相关的信息是放在information_schema表里。所以我们参考 SHOW TABLE STATUS来构建查询语句。如:
- select Auto_increment into autoId from information_schema.tables where Table_Schema = ‘dbname’ and table_name = ‘tablename’;
- 优点:高度自定义,能够准确的得到想得到的任何信息。
以上是关于mysql自增id获取的主要内容,如果未能解决你的问题,请参考以下文章
mysql自增id获取
MySQL中如何获取下一条插入的自增ID
MYSQL获取自增ID的四种方法
MySQL AutoIncrement--PXC集群批量插入操作获取自增ID异常问题
mysql一个表id不是自增的,而且已经有数据了,现在想将id设为自增的sql语句:
MYSQL获取自增ID的四种方法