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

关于mysqlid的获取和重置

缺点:获取的不是真正的id,是表中最大的Id,如果有删除数据的话,那么该值和id相差比较大。如果有连表数据,有可能导致数据错乱。...使用mysql查询函数:SHOW TABLE STATUS; 优点:能够准确的查到id。而且可以在语句后面加上where语句或者like语句来过滤。...缺点:该语句返回的是一个记录集,不能单独的返回增值。所以需要额外的操作来获取。 使用自定义查询方法:mysql表相关的信息是放在information_schema表里。...---- mysqlid的重置 使用truncate:truncate table; 说明:使用truncate会删除表的数据释放空间,并且重置id,但不会删除表的定义。...也不会清空数据,有可能会出现重复key的可能,所以此方法也只适用于清空表之后重置id或者大量删除后修改自id。

11.7K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    面试官:mysql如何重置id

    面试官:咱们聊聊mysqlid。...mysqlid给我们的主键定义带来了很大的方便,但是经常mysqlid会有连续情况,能说说什么场景下mysql的id会产生连续吗我:我以一张表为例来解释一下,我先创建一张表zh_person...我:执行insert into table select这种语句的时候,也会出现id连续的情况,因为mysql申请批量id的策略是对于同一条sql中的申请id,第一次分配一个,如果第一次分配后这个...面试官:存储在内存中,那mysql 服务重启了怎么记录id呢?...我:每次mysql重启都都会查找当前表的最大id值,然后加1存储到内存中作为当前id值 面试官:对这种id连续的情况,对生产有什么影响吗?你有什么好的建议?

    7.4K52

    MySQL主键为什么连续

    不同的引擎对于增值的保存策略不同: MyISAM引擎的增值保存在数据文件中 InnoDB引擎的增值保存在内存里,但是在MySQL8.0以后,该自增值才可以被持久化:MySQL5.7以前,增值没有持久化每次重启后第一次打开表的时候...(默认值是1)开始,以auto_increment_increment(默认值是1)为步长,持续叠加,直到找到第一个大于X的值,作为新的增值 唯一键冲突导致主键连续 insert into t...事务回滚导致主键连续 set autocommit=0; begin; insert into t values(null, 2, 2); rollback; show create table...批量插入导致增值连续 增值锁不是一个事务锁,每次申请完就释放,方便其他事务获取自增值。...) 在innodb_autoinc_lock_mode参数为1的情况下,如果大批量插入数据也会造成id的连续。

    8.4K20

    mysql 主键语句_MySQL 主键

    主键的单调性 为何会有单调性的问题? 这主要跟主键最大值的获取方式,以及存放位置有关系。 如果最大值是通过计算获取的,并且在某些情况下需要重新获取时,会因为最新的数据被删除而减小。...主键最大值怎么取的?存放到哪里?...MySQL 5.7 及之前的版本,主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...从 MySQL 8.0 开始,主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...参考文档 为什么 MySQL主键不单调也连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

    10.8K10

    mysql主键策略_MySQL 主键机制

    对于MyISAM引擎,增值保存在数据文件中; b. Innodb引擎,mysql5.7之前,增值保存在内存中,而且不会持久化增值。...每次重启后第一次打开表,都会去查找增值的最大值max(id), 并设置表当前增值为max(id) + 1; mysql8.0, 增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的值...增值修改发生在插入数据的操作之前,如果插入失败,增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少id锁带来的性能影响,mysql不会修改回去之前的增值; 4....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请 id 的策略(注:该策略是导致 id 连续的第三种原因...:语句执行过程中,第一次申请 id,会分配 1 个;1 个用完以后,这个语句第二次申请 id,会分配 2 个;2 个用完以后,还是这个语句,第三次申请 id,会分配 4 个;依此类推,同一个语句去申请

    9.4K50

    39 | 主键连续

    InnoDB 引擎的增值,其实是保存在了内存里,并且到了 MySQL 8.0 版本后,才有了“增值持久化”的能力,也就是才实现了“如果发生重启,表的增值可以恢复为 MySQL 重启前的值”,具体情况是...: 在 MySQL 5.7 及之前的版本,增值保存在内存里,并没有持久化。...增值的连续情况 1....锁的优化 id 锁并不是一个事务锁,而是每次申请完就马上释放,以便允许别的事务再申请 在 MySQL 5.0 版本的时候,锁的范围是语句级别。...这个参数的值被设置为 0 时,表示采用之前 MySQL 5.0 版本的策略,即语句执行结束后才释放锁; 这个参数的值被设置为 1 时: 普通 insert 语句,锁在申请之后就马上释放; 类似 insert

    4.8K10

    主键连续的几种情况

    //主键连续的几种情况// 最近在极客时间上学习丁奇大佬的《MySQL 45讲》,这里结合自己的理解分享出来,喜欢的同学可以购买原版课程进行学习,里面的内容很丰富。...00 主键介绍 MySQL中的主键想必大家都不陌生,它是通过两个参数来控制的,分别是auto_increment_offset和auto_increment_increment,其中offset...02 事务回滚导致的连续 当我们使用回滚事务的时候,如果该事务内部使用了增值,那么同样会导致表主键出问题,示例如下: mysql> insert into t values (null...03 MySQL锁优化带来的连续 在MySQL5.7中,参数innodb_autoinc_lock_mode被用来控制锁的模式,该参数可以设置为三个值:0、1、2. a、当该值为0的时候,...为了避免id连续而造成的主从数据不一致,线上环境,建议设置成innodb_autoinc_lock_mode=2 ,并且 binlog_format=row.这样做,既能提升并发性,又不会出现数据一致性问题

    3.4K30

    MySQL锁的探究

    2.5 MySQL锁是指在使用主键(Auto Increment)时,为了保证唯一性和正确性,系统会对字段进行加锁。这样可以确保同时插入多条记录时,每条记录都能够获得唯一的增值。...1)插入原理MySQL锁的实现机制是使用了一个名为"auto-increment lock"的互斥锁。...当使用INSERT语句插入一条新记录时,MySQL会自动为字段加锁,防止其他并发的插入操作同时获取相同的增值。这个锁是在内部实现的,不需要用户手动创建或管理。...能够产生一个轻量级的页面锁来保证insert的连续插入;对于Bulk Inserts无法确定插入的行数时采用表级别锁来保证insert的连续插入;2:interleaved(交叉模式):采用表锁,...id连续问题。

    10421

    深入剖析 MySQL

    其实锁(AUTO-INC Locks)这块还是有很多值得讨论的细节,例如在并发的场景下,InnoDB 是如何保证该值正确的进行的,本章就专门来简单讨论一下 InnoDB 中的锁。...什么是锁 之前我们提到过,锁是一种比较特殊的表级锁。...行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...基于 MySQL 默认 Binlog 格式从 Statement 到 Row 的变更,InnoDB 也将其锁的默认实现从连续模式,更换到了效率更高的交叉模式。...并且,没有了主从同步,INSERT 语句在从库乱序执行导致的 AUTO_INCREMENT 值匹配的问题也就自然不会遇到了。 总结 你可能会说,为啥要了解这么深?有啥用?

    3.3K40

    深入剖析 MySQL

    其实锁(AUTO-INC Locks)这块还是有很多值得讨论的细节,例如在并发的场景下,InnoDB 是如何保证该值正确的进行的,本章就专门来简单讨论一下 InnoDB 中的锁。...什么是锁 之前我们提到过,锁是一种比较特殊的表级锁。...行为与限制 其实上面说的那种阻塞情况只是锁行为的其中一种,可以理解为锁就是一个接口,其具体的实现有多种。...基于 MySQL 默认 Binlog 格式从 Statement 到 Row 的变更,InnoDB 也将其锁的默认实现从连续模式,更换到了效率更高的交叉模式。...并且,没有了主从同步,INSERT 语句在从库乱序执行导致的 AUTO_INCREMENT 值匹配的问题也就自然不会遇到了。 总结 你可能会说,为啥要了解这么深?有啥用?

    3K20

    数据库主键一定要吗?有哪些场景建议

    主键id不自的情况 没有主键可以吗 mysql表如果没有主键索引,查个数据都得全表扫描,那既然它这么重要,我今天就不当人了,声明主键,可以吗? 嗯,你完全可以声明主键。...隐藏的row_id列 有没有建议主键不自的场景 前面提到了主键可以带来很多好处,事实上大部分场景下,我们都建议主键设为。 那有没有建议主键的场景呢?...tidb的主键id建议 tidb是一款分布式数据库,作为mysql分库分表场景下的替代产品,可以更好的对数据进行分片。...用户id建议用id 前面提到的建议使用id的场景,都是技术原因导致的,而下面介绍的这个,单纯是因为业务。 举个例子吧。...当然,主键保持,但是暴露给前端,那也行,那前面的话,你当我没说过。

    6.2K33
    领券