mysql自增ID跳跃增长

mysql自增ID跳跃增长,第1张

#1、查看现在mysql自增id的配置

show variables like '%increment%'

#2、下面步长为2的增长

+-------------------------------+-------+

| Variable_name                 | Value |

+-------------------------------+-------+

| auto_increment_increment      | 2    |

| auto_increment_offset         | 1     |

| div_precision_increment       | 4     |

| innodb_autoextend_increment   | 8     |

| ndb_autoincrement_prefetch_sz | 32    |

+-------------------------------+-------+

5 rows in set (0.01 sec)

#3、解决

set auto_increment_increment = 1和set @@auto_increment_increment = 1

如果想永久性的改回为1,在my.cnf or my.ini中查找这个field,然后修改,然后restart mysql.

一、修改自增长序列的值

alter table table_name auto_increment=n

注意:n只能大于已有的auto_increment的整数值,小于的值无效.

show table status like 'table_name' 的返回结果里的auto_increment列就是表的现有值.

二、控制主键的起点

create table 表名

(

......

) engine=INNODB auto_increment=1001 default charset=gbk

三、自增主键归零

如果曾经的数据都不需要的话,可以直接清空所有数据,并将自增字段恢复从1开始计数

truncate table 表名

四、获取自增主键

通过SQL select LAST_INSERT_ID()函数

通过SQL @@IDENTITY 变量

五、说明

AUTO_INCREMENT数据列必须有唯一索引,以避免序号重复。

AUTO_INCREMENT数据列必须具备NOT NULL属性。

设置AUTO_INCREMENT属性的数据列应该是一个正数序列,所以应该把该数据列声明为UNSIGNED,这样序列的编号个可增加一倍。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/6115546.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-15
下一篇2023-03-15

发表评论

登录后才能评论

评论列表(0条)

    保存