首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL重新设置auto_increment

需求描述 通常,我们都会在数据库表中设置一个自增字段作为主键,该字段的值会随着添加新记录而自增。 同时也必须注意,这个自增字段的值只会一直增加,即使把记录删除了,该自增字段的值也不会变小。...处于某种目的,如果希望该自增字段值一定是连续的,有2种解决办法: 1.表记录不允许物理删除 2.物理删除表记录后重新设置auto_increment 在此,专门针对重新设置auto_increment...更新auto_increment值 在修改表的auto_increment值之前需要先查看当前值是多少: mysql> select auto_increment from information_schema.tables...为了使得新添加的记录自增ID再次继续从50003开始计数,执行如下语句: mysql> alter table 表名 AUTO_INCREMENT=50002; 最后总结 直接修改auto_increment.../fdipzone/article/details/50421831 MySql查看与修改auto_increment方法

1.7K20

MySQL auto_increment_increment,auto_increment_offset 用法

MySQL中对于表上ID自增列可以在创建表的时候来指定列上的auto_increment属性;等同于SQL server中的identity属性;Oracle则是通过Sequence方式来实现。...在MySQL中,系统变量auto_increment_increment,auto_increment_offset 影响自增列的值及其变化规则。本文主要描述这两个系统变量的相关用法。...-------+------------+ | version | 5.5.39-log | +---------------+------------+ root@localhost[mysql...]> create database tempdb; root@localhost[mysql]> use tempdb; --查看变量auto_increment_increment与auto_increment_offset...与auto_increment_offset取值范围 --将变量auto_increment_increment设置为0 root@localhost[tempdb]> set session auto_increment_increment

1.5K30
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL字段自增长AUTO_INCREMENT用法实例详解

为了验证这个怀疑的准确性,同时学习下InnoDB处理 AUTO_INCREMENT 的机制,因此在测试环境做了测试总结。 本文使用的MySQL版本为官方社区版 5.7.24。...大量插入导致的间隙 当参数值 innodb_autoinc_lock_mode 设置为 0 或 1 时,每条语句生成的自增列值都是连续的,不会产生间隙。...因为表级 AUTO-INC 锁会一直持有直到语句结束,并且同一时间只有一条语句在执行; 当参数值 innodb_autoinc_lock_mode 设置为 2 时,在大量插入时有可能会产生间隙,但是只有当并发执行...对于设置成 1 或者 2 情形下,在连续的语句之间可能产生间隙,因为对于大量插入InnoDB并不清楚每条语句所需自增量值数量。...参考 https://dev.mysql.com/doc/refman/5.7/en/innodb-auto-increment-handling.html

5K20

MySQL中的字段约束 null、not null、default、auto_increment

今天我们来看一下MySQL的字段约束:NULL和NOT NULL修饰符、DEFAULT修饰符,AUTO_INCREMENT修饰符。...MySQL默认情况下指定字段为NULL修饰符,如果一个字段指定为NOT NULL,MySQL则不允许向该字段插入空值(这里面说的空值都为NULL),因为这是“规定”。...当插入记录时,您老人家忘记传该字段的值时,MySQL会自动为您设置上该字段的默认值。 如果一个字段中没有指定DEFAULT修饰符,MySQL会依据这个字段是NULL还是NOT NULL自动设置默认值。...如果指定字段可以为NULL,则MySQL为其设置默认值为NULL。...NOT NULL DEFAULT '' 不能为null 默认为 '' NULL DEFAULT NULL 可以为null 默认为null AUTO_INCREMENT 修饰符: AUTO_INCREMENT

5.3K20

python mysql自增字段AUTO_INCREMENT值的修改方式

这个时候我们就要学习去修改数据表的一些属性值了,而这个属性值就是AUTO_INCREMENT。 首先我们要知道怎么查看这个属性的值。...utf8; 那么接下来我可以通过命令来查看AUTO_INCREMENT的值: ?...此时我们可以找到AUTO_INCREMENT这个属性,并且它的值等于4,这个是不是就是说明AUTO_INCREMENT记录的值表示对于下一条记录的id值。...通过alter table t4 AUTO_INCREMENT=2;这个命令我们可以修改AUTO_INCREMENT属性的值,将其修改为2,那么我们再添加数据,id不就从2开始了嘛。...至于原因:django要求是这样的,你可以不设置这个参数,如果要设置请与你的app名称保持一致。而我就是犯了这样的错误。

2.7K10

记一次Auto Increment故障

在一个月黑风高的晚上,苦逼的程序员被一阵急促的报警短信声惊醒,原来是数据库的某个表出问题了,虽然查询操作都正常,但创建操作却都失败了,经过调试,发现原因是表被插入了一行问题数据,其自增字段的值被显式的设置为整型的最大值...既然理清了问题的原因,那么第一感觉就是把 Auto Increment 字段的计数器复位,设置到一个合理的值,我们可以在删除问题数据后尝试执行如下语句: ALTER TABLE test AUTO_INCREMENT...= 123; 此方法无疑能够达到目的,但有一个缺点:在 MySQL 中,当 ALTER 一个表时,实际上相当于重新创建了一次表!...让我们再来考虑考虑其它方法,既然问题出在唯一标识的隐式设置上,那么我们不妨换个思路,显式设置唯一标识,比如说通过「SELECT MAX … FOR UPDATE」的方式直接查询得到唯一标识符,并在稍后执行的...INSERT 语句中显式设置

33520

mysql乱码设置

MySQL默认字符编码的设置 MySQL的默认编码是Latin1,不支持中文,那么如何修改MySQL的默认编码呢,下面以UTF-8为例来说明  需要注意的是,要修改的地方非常多,相应的修改方法也很多...下面是一种最简单最彻底的方法:  一、Windows  1、中止MySQL服务  2、在MySQL的安装目录下找到my.ini,如果没有就把my-medium.ini复制为一个my.ini...即可  3、打开my.ini以后,在[client]和[mysqld]下面均加上default-character-set=utf8,保存并关闭  4、启动MySQL服务  二、Linux... 1、中止MySQL服务(bin/mysqladmin -u root shutdown)  2、在/etc/下找到my.cnf,如果没有就把MySQL的安装目录下的support-files...服务(bin/mysqld_safe &)  非常简单,这样的修改一劳永逸,今后MySQL一切相关的默认编码均为UTF-8了,创建新表格的时候无需再次设置  需要注意的是,当前数据库中已经存在的数据仍保留现有的编码方式

3.8K60

MySQL数据表中的auto_increment自增值属性及修改

环境说明: MySQL 5.7 、MySQL 8.0 长期以来,我的博客数据库中连续文章的主键编号一直都不是连续的,让我这个强迫症晚期患看着很不舒服。...修改自增初始值与自增量的命令: SET @@AUTO_INCREMENT_INCREMENT=新初始值; SET @@AUTO_INCREMENT_OFFSET=新步长; 注意:这个表示的是数据库全局的自增设置...,因此修改以后只会影响到下次新增的带有 AUTO_INCREMENT 属性的列,其自增初始值与自增步长就是新设置的值,对当前已经带有 AUTO_INCREMENT 属性的列的自增初始值与自增步长不起作用...所以,对于具有 AUTO_INCREMENT 属性的列,不用特意设置列值,而是直接将 NULL 值插入到自增列中去,数据库会自动根据当前的自增值生成列值。...这属实让我有点摸不着头脑,我也不太确定是不是 MySQL 版本不同的原因,也懒得再尝试了,所以把这种情况记录上来以供参考吧。

2.2K10

MySQL错误解法-1467: Failed to read auto-increment value from storage engine

将日志打印的插入SQL到命令行直接执行,同样提示1467错误,并有了更详细的说明: ERROR 1467 (HY000): Failed to read auto-increment value from...COMMENT '自增主键', …… ) ENGINE=InnoDB AUTO_INCREMENT=18446744073 DEFAULT CHARSET=utf8 可见当前的自增逐渐的范围是11...位无符号整型,而最后的AUTO_INCREMENT的值其实就是记录当前表中最大的自增主键的值是多少,可以看到已经达到了11位,无法继续增加,才会报错。...然后查到正常增长到的ID,假设是12666,执行以下语句: ALTER TABLE T_XX AUTO_INCREMENT = 12666; 此时再查看建表语句,就会发现已经恢复了游标,可以继续插入了:...COMMENT '自增主键', …… ) ENGINE=InnoDB AUTO_INCREMENT=12666 DEFAULT CHARSET=utf8

1.1K10
领券