范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

面试官mysql重启后自增id是从几开始增加

  在mysql中用自增列作为主键时,先往表里插入5条数据,此时表里数据id为1、2、3、4、5,如果此时删除id=4、5的数据后,再重启数据库,重启成功后向表里插入数据的时候,innodb、myisam引擎下ID分别是从几开始增加?如果你没经历过,或者当面试时被问到这个问题时,相信多数人都是一脸懵逼。MD 谁有事没事去重启线上数据库嘛。最主要的是很多没有测试过这个场景,没有这方面的经验,我在这里做个笔记,大家轻喷!
  MySQL 通常使用的引擎都是 INNODB,在建表时,一般使用自增列作为表的主键,这样的表对提高性能有一定的帮助。但是自增列有一个坑,并且这个坑存在了很久,一直到 MySQL 8.0 版本,才修复了这个坑,这个坑就是表的自增列变量 auto_increment 在 MySQL 重启后,有可能丢失。  「innodb 引擎(低版本):Innodb 表中把自增列作为主键 ID 时,自增列是通过 auto-increment 计数器实现的,计数器的最大值是记录到内存中的,重启数据库后,会导致 auto-increment 计数器重置,从而会导致主键 ID 重置。」 「MyISam 引擎:MyISAM 表会把自增列(auto-increment 计数器)最大值是记录到数据文件里,重启 MySQL 自增列(计数器)最大值不会丢失,从而使用自增列作为主键 ID 时也不会丢失。」 innodb 主键重置问题
  在 MySQL 低版本中,InnoDB 表中使用自增的 auto-increment 计数器 会把值存放在内存中,不会写入磁盘。一旦 MySQL 服务重启,这个值就丢了,InnoDB 引擎会根据表中现有的数据重新计算该计数器的值:获取表中最大的自增主键 ID 作为auto-increment 计数器的最大计数,当 insert 数据时,在 auto-increment 计数器最大值上 1。
  先创建一张 user 表,新增几条数据:  //1.创建user表:自增列作为主键ID CREATE TABLE `user` (   `id` int(11) unsigned NOT NULL AUTO_INCREMENT,   `name` varchar(255) NOT NULL DEFAULT "",   `age` int(4) unsigned NOT NULL DEFAULT "0",   PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;  //2.插入5条数据 INSERT INTO `user`(`name`, age) VALUES("刘备1", 21); INSERT INTO `user`(`name`, age) VALUES("刘备2", 22); INSERT INTO `user`(`name`, age) VALUES("刘备3", 23); INSERT INTO `user`(`name`, age) VALUES("刘备4", 24); INSERT INTO `user`(`name`, age) VALUES("刘备5", 25);场景一mysql数据库不重启时「mysql 数据库不重启时,innodb 自增主键 ID 会根据 auto-increment 计数器一直递增。」
  向 user 表里插入 5 条数据,主键 ID 按自增列通过 auto-increment 计数器实现自增。
  在 user 表里删除 id 为 4、5 的数据,再向 user 表中插入一条数据,主键 ID 是 auto-increment 的值 6。
  场景二mysql数据库重启后
  mysql 数据库重启后,innodb 自增主键 ID 会根据 auto-increment 计数器的重置而重置。
  在场景一的基础上,在删除 id 为 6、3 的数据后,此时 auto-increment 计数器的值为 7,user 表里的 id 最大是 2。
  然后重启数据库后,auto-increment 计数器的值变为 3,也就是 user 表里的自增列 ID 的最大值 2 加 1。
  此时在插入数据时,自增 ID 会从 3 开始自增。Innodb 表中把自增列作为主键 ID 时,在 mysql 重启后就会存在 ID 重置问题。**删除数据后,再重启,AUTO_INCREMENT 会查询表里最大 ID 并进行重置,重置后和重启前AUTO_INCREMENT 计数器的值不同。**在 MyISAM 引擎表中的自增列不会存在这个问题。
  MySQL 8.0 auto-increment 计数器逻辑
  在 MySQL 8.0 中,这个计数器的逻辑变了:每当计数器的值有变,InnoDB 会将其写入 redo log,保存到引擎专用的系统表中。MySQL 正常关闭后重启:从系统表中获取计数器的数值。MySQL 故障后重启:从系统表中获取计数器的值;从最后一个检查点开始扫描 redo log 中记录的计数器值;取这两者的最大值作为新值。
  总结
  如果 mysql 重启了,那么 innodb 表在启动后,AUTO_INCREMENT 会自动检测出、并重置为当前表中自增列的最大值 +1。2)假如一个表格里 AUTO_INCREMENT 计数器的值是 10,此时执行update table set id = 15 where id = 9后,如果这时再继续插入数据,到了自增 ID=15 的时候是会报错。但是这个时候继续插入,就不会报错。因为刚才即使报错了,AUTO_INCREMENT 的值依旧会增加。3)现在使用的一般都是 innodb 引擎,如果将 myisam 引擎转换过来的时候,一定要小心这个引擎在自增 id 上的不同表现。在主从使用不同引擎的时候,也会出现问题,最好将引擎改完一致性的。

拼多多买车历程和建议分享本内容来源于什么值得买APP,观点仅代表作者本人作者挥泪剁手的张大妈今天终于有空闲下来编辑一篇文章了,我文爱不太好,就简单的说说我在网上买车的经过和建议,希望能够帮助到各位值友。最华为智能眼镜新功能上线被红包提醒包围的感觉,Nice2022年农历春节将至,年味也越来越浓。对很多人来说,年味是一种只可意会不可言传的美好,它也许藏在高高悬起的大红灯笼和家门口张贴的对联里,也可能藏在香味四溢的年夜饭和兜里甜甜的糖瓜图片上有文字,用什么软件可以把图片上的文字转换出来?现在美图秀秀有一个功能就可以,打开美图秀秀,点美化图片,以吴昕这张照片为例,这张照片右下角有水印,现在我们就可以用美图秀秀消除点击消除笔的这个功能就可以进入下个页面,点击画笔,将水苹果汽车团队软件工程主管离职乐视汽车北京公司被强制执行苹果汽车团队软件工程主管离职,此前管理团队几乎全部离职据新浪科技报道,苹果汽车软件工程主管乔巴斯已经离职。随着巴斯的离开,苹果一年前的汽车管理团队几乎全部离职。巴斯现在是Meta公小米大跌5再破发!一年市值蒸发4000亿,雷军又下载炒股软件?1月27日,小米集团延续跌势。盘中大跌超5报16。5港元股,总市值4100亿港元。据悉,该股价同时刷新了近52周来最低,同时再次跌破发行价。财经天下周刊发现,自年初创造35。9港元字节腾讯京东22家大厂虎年礼盒实测,互联网公司团拜会来了36氪和他的朋友们春节版!编辑王哥撰文制图聂老师王哥夏老师李主任嗷嗷拍摄李主任聂老师王哥夏老师视觉小蜜蜂来源超人测评当当当当!又到了最受超人测评读者们喜爱的36氪和他的朋友们大厂礼中科营商大数据科技(北京)有限公司核心价值观为什么热爱,务实,创新,专业,是中科营商大数据科技(北京)有限公司的核心价值观?热爱,是干一行,爱一行的源动力,没有热爱,成就不了事业。没有热爱,你做事就是小时工思维。热爱是生活工韩媒三星LG春节前向合作公司提前支付20亿美元货款韩国中央日报1月26日报道,三星25日表示,包括三星电子在内的11个子公司计划最多提前15天支付1。1万亿韩元(约9。18亿美元)规模的合作公司货款。三星从2004年开始就提前进行iPhone13升级iOS15。3真实感受目前最值得升级的系统版本iPhone13是直接OTA升级iOS15。3正式版的,没有用线刷,有很多人认为线刷会更流畅稳定一些,但个人认为没什么区别,不然苹果官方为什么还要推送呢?再来分享下iPhone13中国新能源单一车型销冠!宏光MINI全年销量426,452台2022年1月14日今日,上汽通用五菱宣布,截止到2021年12月31日,宏光MINIEV上市至今整体销量突破55万,其中2021全年销量累计426,452台,问鼎新能源年度销冠,国产操作系统的希望,被称中国版微软,UOS能否替代Windows?UOS走不出去国门,那么用户数就始终不可能与微软Windows这样的主流操作系统相比,哪怕全中国都使用了UOS,UOS也是无法与微软Windows相比的,所以UOS取代Window
上网慢信号差?看看是不是路由器卡了,赶紧重启一下家里的路由器长时间使用,到底要不要关机重启?多久关一次?8月12日,上游新闻记者专访重庆移动家庭业务管理人员,为你打探路由器的使用指南,怎样使用路由器才能让路由器更长寿,也让家里的你的专属刷牙助手米家声波电动牙刷T700体验随着越来越多的人开始关注口腔卫生,电动牙刷的普及度越来越高,以前动辄数百元的电动牙刷现在价格也有了大幅的下降。米家也推出了多款不同定位的电动牙刷,在今年上半年,米家也进一步完善了电新电脑越用越慢怎么办?小A来教你秘技其实,以近两年的笔记本配置来看,办公娱乐完全没问题,即便用了几年。那为什么还会卡呢?也许是跟大家的使用习惯有关,今天小A就跟大家来聊聊如何改善电脑变慢的问题。新软件拿到手,你是不是为什么男生会选择iphone而不是黑鲨?小编发现,纵使身边的男生很喜欢玩游戏,但是他们的手机都是iphone居多,其次华为小米,OPPOvivo基本看不到男生们用。但是平常刷DYKS关于游戏手机又会有很多男生评论。那么问机械键盘常见轴体如何选机械键盘先选择键盘轴体,键盘分特别多的轴体,轴根据不同的键程和压力,分为红轴茶轴黑轴青轴和白轴青轴的特点拥有着最强的段落感,清脆就是青轴给人最大的感受。青轴的缺点扰民,极其扰民。青使用华为P50Pro两周后,我们找到了这些超实用的小功能从P9与徕卡联名开始,华为的P系列手机就成了自家的影像担当。作为华为新一代影像旗舰,今天正式开售的P50Pro,拍照能力无疑令人期待。但影像并不是唯一值得关注的。毕竟,手机买回来,腾讯搬运账号识别功能曝光!太方便了不知道各位有没有遇到过被侵权的困扰?创作不易,自己辛辛苦苦创作的作品被他人轻轻一个ctrlc就拿去了,谁会不气?近日,腾讯获得了一项专利授权,或许能方便你我他。腾讯搬运账号识别专利股价半年下跌近60,市值蒸发1500亿美元,资本宠儿拼多多为什么不香了段永平曾评价我只是说过我相信黄峥,但对整个团队没了解过,对拼多多的商业模式也一直没搞懂。当亏损换增长的故事不再性感,拼多多需要一个更精彩的新故事。文中国企业家记者程璐编辑李薇头图摄黑客盗走6亿美元加密货币又归还2。6亿自称就是玩,对钱没兴趣据BBCCNN等外媒报道,8月10日晚,区块链网站PolyNetwork遭到黑客攻击,利用漏洞盗走了大量加密货币,包括以太坊等,总计价值约6。1亿美元,这是全球加密货币史上最大规模PolyNetworkDefi黑客返还大量代币,Chainalysis评估黑客链上运动8月11日,区块链情报公司Chainalysis发布了有关最近PolyNetwork黑客攻击的调查结果,该事件造成大约6。11亿美元的加密代币损失。Chainalysis的评估支持您的iPhone还能再战几年?进来测测大家可能关心过手机使用寿命问题,一台旗舰手机究竟能用多少时间呢?据咆哥的个人经验来判断,iPhone应该在35年,而安卓旗舰手机一般在23年左右。造成安卓用户换机频繁的原因有很多,