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

python mysql字段AUTO_INCREMENT修改方式

在之前得文章中我们说过,如果使用delete对数据库中得表进行删除,那么只是把记录删除掉,并且id的还会保持上次的状态。 即删除之前如果有四条数据,删除之后,再添加新的数据,id怎会从5开始。...但是我们显示想让id从2开始,应该怎么做呢? 这个时候我们就要学习去修改数据表的一些属性值了,而这个属性就是AUTO_INCREMENT。 首先我们要知道怎么查看这个属性的。...这是因为我们刚建好表,还没有数据,所以这个属性还没开始被赋值。...可以发现表的信息并没有因为表里的信息被删除而改变,这样的话,我们要是想让添加的数据id从2开始不就会不行了吗? but,我们可以修改表的信息。...通过alter table t4 AUTO_INCREMENT=2;这个命令我们可以修改AUTO_INCREMENT属性的,将其修改为2,那么我们再添加数据,id不就从2开始了嘛。

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

mysql修改起始

背景: A表带键,B表不带,通过程序从A表同步数据到B表,同步完成后会通过delete删除A表数据,今天插入B表会出现duplicate primary key问题。...A: select max(id) from A; auto_increment id=58000; B: 只有主键没有键 select id from B by id desc limit...A的增列起始,通过如下命令 alter table A auto_increment=2000000; 修改后起始从200w开始。...操作会导致AUTO\_INCREMENT 从1开始, **主因**: 后来发现主要原因是所在实例重启造成的,auto_increment的增值在mysql8.0之前一直是记录内存中的, 当实例重启的时候该会丢失...,那么mysql会取select max(id) + 1 的作为新插入数据的ID, 这样启动后就A表从58000开始而不是1873741开始,这样造成插入B表会重复

3.4K30

mysql 主键语句_MySQL 主键

主键的单调性 为何会有单调性的问题? 这主要跟主键最大的获取方式,以及存放位置有关系。 如果最大是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删除而减小。...主键最大怎么取的?存放到哪里?...MySQL 5.7 及之前的版本,主键最大会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...从 MySQL 8.0 开始主键最大会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的。...其他 如果主动指定 ID 为 0 或者 NULL 插入,则会使用数据库生成的 ID。

10.8K10

mysql主键策略_MySQL 主键机制

每次重启后第一次打开表,都会去查找增值的最大max(id), 并设置表当前增值为max(id) + 1; mysql8.0, 增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的...增值修改策略? a. 在插入时如不指定或指定为0,null,则使用当前的增值填到字段;并设置当前增值=当前增值+auto_increment_increment 步长; b....指定了具体的,若指定小于当前增值,则增值不发生改变;若大于当前增值,则增值为指定+auto_increment_increment; 3. 增值的修改时机? a....增值修改发生在插入数据的操作之前,如果插入失败,增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少id锁带来的性能影响,mysql不会修改回去之前的增值; 4....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请 id 的策略(注:该策略是导致 id 不连续的第三种原因

9.4K50

浅谈MySQL

如果存在字段,MySQL会维护一个锁,和锁相关的一个参数为(5.1.22版本之后加入) innodb_autoinc_lock_mode:可以设定3个,0,1,2 0:traditonal...六、的过程 第一种,插入空的时候 当innodb_autoinc_lock_mode=0时 1、申请AUTO_INC锁 2、得到当前的AUTO_INCREMENTn,并加1 3、执行插入操作...第二种,插入已经有 1、插入第一条数据 2、如果失败流程结束 3、如果成功,申请AUTO_INC锁 4、调用set_max函数,修改AUTO_INCREMENT 5、语句结束,释放AUTO_INC...为了保证主库和从库的ID的一致性,binlog中会有set insert_ID命令,标明这个load语句的第一行的ID,这样在表锁的情况下,就可以保证一致性了。...锁分享就到这里了。

5K30

MySQL锁的探究

2.5 MySQL锁是指在使用主键(Auto Increment)时,为了保证唯一性和正确性,系统会对字段进行加锁。这样可以确保同时插入多条记录时,每条记录都能够获得唯一的增值。...1)插入原理MySQL锁的实现机制是使用了一个名为"auto-increment lock"的互斥锁。...当使用INSERT语句插入一条新记录时,MySQL会自动为字段加锁,防止其他并发的插入操作同时获取相同的增值。这个锁是在内部实现的,不需要用户手动创建或管理。...Tips:锁跟事务无关,即使多个insert语句存在同一个事务中,每次insert都会申请最新的锁来获取最新的AUTO_INCREMENT;获取到增值后释放,而不是事务结束释放;2)锁表锁需要注意的是...这也是InnoDB的默认;Simple inserts:InnoDB能够预先知道要插入的行数,因此产生的锁只会锁住对应的那些id(页锁),避免表级别的锁Bulk Inserts:InnoDB无法预知要插入的行

9321

深入剖析 MySQL

其实锁(AUTO-INC Locks)这块还是有很多值得讨论的细节,例如在并发的场景下,InnoDB 是如何保证该正确的进行的,本章就专门来简单讨论一下 InnoDB 中的锁。...什么是锁 之前我们提到过,锁是一种比较特殊的表级锁。...行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...在 MySQL 8.0 之前,InnoDB 锁模式默认为连续模式,为1,而在 MySQL 8.0 之后,默认模式变成了交叉模式。至于为啥会改变默认模式,后面会讲。...基于 MySQL 默认 Binlog 格式从 Statement 到 Row 的变更,InnoDB 也将其锁的默认实现从连续模式,更换到了效率更高的交叉模式。

3.2K40

深入剖析 MySQL

其实锁(AUTO-INC Locks)这块还是有很多值得讨论的细节,例如在并发的场景下,InnoDB 是如何保证该正确的进行的,本章就专门来简单讨论一下 InnoDB 中的锁。...什么是锁 之前我们提到过,锁是一种比较特殊的表级锁。...行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...在 MySQL 8.0 之前,InnoDB 锁模式默认为连续模式,为1,而在 MySQL 8.0 之后,默认模式变成了交叉模式。至于为啥会改变默认模式,后面会讲。...基于 MySQL 默认 Binlog 格式从 Statement 到 Row 的变更,InnoDB 也将其锁的默认实现从连续模式,更换到了效率更高的交叉模式。

2.9K20

数据库中设置列字段(Oracle和Mysql

oracle 1、创建一个序列,然后在需要的字段里使用它 drop sequence seq_stu create sequence seq_stu start with 22 Increment...by 1 maxvalue 999 nocache nocycle; --这是最详细的一种序列的创建,指定了序列从22开始,到999结束,每次使用后都1 create sequence seq_stu...--这是最简单的一种序列的创建方式,指定了序列从1开始,每次使用后都1 drop sequence seq_stu; --删除序列(seq_stu为序列名) 2、数据的插入(序列名.nextval...表名; 注意:截断表,即删除所有数据,只保留表结构 Mysql 创建表时直接制定增列/字段 1、通过点击点击相关表选择“设计表”进行设置 ?...如何重置数据表中 TRUNCATE TABLE 表名; 注意:会删除表中的数据,只有在MySQL中,TABLE字段可省略

7.2K20

MySQL主键值回溯问题

平时我们使用MySQL时,通常每一个表都会有一个主键ID,每新增一条数据,ID就会1。但在8.0之前版本的MySQL中,这个增值会存在一个回溯的问题。...例如,在一个新表中插入三条主键为1、2、3的数据行,这时候用SHOW CREATE TABLE命令查看该表的AUTO_INCREMENT的是4,这是没问题的。...然后把ID=3的数据行删掉,再次查询AUTO_INCREMENT的,依然是4,这也是没问题的。 但如果重启一下MySQL,这个就会变回3,而不是4,发生了回溯。...这是因为AUTO_INCREMENT的只存储于内存中,不会持久化到磁盘,每次启动数据库时,MySQL会通过计算max(auto_increment字段) + 1,重新作为该表下一次的主键ID的增值。...这个问题直至MySQL 8.0才修复。 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/149188.html原文链接:https://javaforall.cn

4.1K20

MySQL 主键注意事项

很多小伙伴应该知道,在 MySQL 中主键不应该使用随机字符串。但是主键不用随机字符串用什么?主键?主键就是最佳方案吗?有没有其他坑?今天我们就来讨论下这个话题。 1....基于上面的分析,我们在 MySQL 中尽量不使用 UUID 作为主键,不用 UUID,可能会有小伙伴想到,那我使用主键行不行?...2.2 innodb_autoinc_lock_mode 我们可以通过控制 innodb_autoinc_lock_mode 变量的,来控制在主键的时候,MySQL 锁的处理思路。...SQL 语句开始的时候,获取到一个表级的 AUTO-INC 锁,然后当插入 SQL 执行完毕之后,再释放掉这把锁,这样做的好处是可以确保在批量插入的时候,主键是连续的。...小结 好啦,这就是关于主键的一个小小知识点,小伙伴们一定要根据实际情况来为 innodb_autoinc_lock_mode 属性取一个合适的

6310

MySQL主键详解「建议收藏」

; 在MySQL8.0版本,将自增值的变更记录在了redo log中,重启的时候依靠redo log恢复重启之前的 二、增值修改机制 如果字段id被定义为AUTO_INCREMENT,在插入一行数据的时候...假设,某次要插入的是X,当前的增值是Y 1.如果X<Y,那么这个表的增值不变 2.如果X>=Y,就需要把当前增值修改为新的增值 新的增值生成算法是:从auto_increment_offset...(初始开始,以auto_increment_increment(步长)为步长,持续叠加,直到找到第一个大于X的,作为新的增值 三、增值的修改时机 创建一个表t,其中id是主键字段、c是唯一索引...出现了主键不连续的情况 唯一键冲突和事务回滚都会导致主键id不连续的情况 四、锁的优化 id锁并不是一个事务锁,而是每次申请完就马上释放,以便允许别的事务再申请 但在MySQL5.0版本的时候...也就是说,如果一个语句申请了一个表锁,这个锁会等语句执行结束以后才释放 MySQL5.1.22版本引入了一个新策略,新增参数innodb_autoinc_lock_mode,默认是1 1.这个参数设置为

5.8K40
领券