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

面试官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 上的不同表现。在主从使用不同引擎的时候,也会出现问题,最好将引擎改完一致性的。

冬季连续使用空调,需要耗多少电?知道之后你还敢用空调取暖吗?冬季连续使用空调,需要耗多少电?知道之后你还敢用空调取暖吗?空调现在也是一家没有必备的一种家用电器了,在夏季的时候我们都会选择使用空调来制冷,到了冬季的时候很多朋友也会选择使用空调华为联名保时捷,OPPO联盟兰博基尼,如今奔驰也迎来2款联名手机随着K50发布时间越来越近,小米的宣传也越来越疯狂。这不前两天还在官宣RedmiK50电竞版将会联名奔驰?第一时间看到的我内心直乎好家伙!现在连走性价比的机型预算都这么充足了吗!要手机4G网速越来越卡,流量上网速度慢?教你一招,快速搞定本文编辑今日头条作者小俊技术分享未经授权严禁转载,发现抄袭者将进行全网投诉分享生活小妙招,享受科技新生活!大家好,欢迎来到今天的知识分享!我是你们的好朋友小俊!我们在使用手机流量网联想将于2月28日举办拯救者手机发布会36分充满电目前各大手机厂商已经推出了第一批基于骁龙8Gen1的手机终端,而在二月份则是一大波游戏手机厂商发布自家上半年旗舰手机的时间,其中就包括红魔红米等,目前联想拯救者也公布了发布会时间,这部其貌不扬的诺基亚手机,二手已经卖到了2万块说起诺基亚手机的巅峰时期,大概是在2003年到2008年期间,主要以Symbian系统智能手机为主,经典的机型从66007610到N70,N73比比皆是。但是,哪怕当年上万元的诺基华为手机最新专利技术摄像头测肤质,提供护肤建议手机市场竞争激烈,各大品牌竞相研发专利技术让品牌保持竞争力。随着手机越来越重视拍摄功能和摄像技术,国产知名品牌华为最近推出新的皮肤分析技术,为用家的皮肤打分数。这项三摄像头3D智能余承东内部讲话疯传干翻特斯拉,揶揄小米,等华为手机王者归来余承东的魅力有多大?那就是淡隐江湖大半年,随便流出个内部讲话,就成为各大网站头版头条!这人气,不服不行!2月15日,一段余承东内部讲话的视频流出,这段备注随时下架(也确实被不断下架这个透明手机壳给我焊手机上!太好看了吧既然费了这么多心思选好了心仪颜色的iPhone13,自然得选一款通透的优质透明壳,来好好展示它的颜色,如果买了新手机却不用透明保护壳,那选颜色的意义在哪里呢。说到透明的手机壳,必须男子投资朋友公司100万只要分红,却被告知没分红,不是股东?近日,小白的朋友老黑新开了一家新能源科技公司,注册资本1000万元。小白看好新能源的项目,决定投资朋友的这家新能源科技公司100万元,持股期间不参与公司的经营管理,只享受公司每年的喝水一步到位净饮机上位免去了购买瓶装水桶装水的麻烦,却能一步到位喝到纯净水净水器加即热饮水机的组合是不少家庭健康饮水的新选择。2021年,随着产品迭代升级,净饮机的出现再次打破这一格局,机构预测2022对话OpenSea联创Alex我们的最大竞争优势是可选择性来源CryptoStanford受访者AlexAtallah编译麟奇,链捕手OpenSea是世界上最大的NFT交易市场,也是NFT行业爆发的最大赢家之一,但去年年底以来面临着被批不
工信部重拳整治屏蔽乱象,网友太有必要了根据21世纪经济报道,9月9日下午,工信部有关业务部门召开了屏蔽网址链接问题行政指导会。会上,工信部提出有关即时通信软件的合规标准,要求限期内各平台必须按标准解除屏蔽,否则将依法采浅析汽车OTAOTA(OvertheairTechnoloogy)即空中下载技术,是通过移动通信的空中接口实现对移动终端设备及SIM卡数据进行远程管理的技术,是一种为设备分发新软件配置,乃至更新自动驾驶汽车新四化中国的汽车行业面临着百年不遇的深刻变革,从新能源电动车的弯道超车,到自动驾驶的起步追赶,都预示着中国汽车行业发展的野心,近几年,汽车新四化地提出,给中国汽车的发展奠定了方向,作为自聊聊自动驾驶汽车会沦为下一个广告终端吗?工作了一天的我们,放下了工作时紧张的心情,不想再被打扰,但走进电梯,找工作,和老板谈婚纱照,去哪儿拍?等洗脑广告还是会不断向我们袭来,不论想不想看,洗脑广告就在这里,不管想不想听,自动驾驶汽车隐私安全探究在自动驾驶普及之后,驾驶员的角色将进入历史尘埃,所有人都会转变为乘客的角色,每辆汽车都会规规矩矩地在道路行驶,每辆汽车都会保持在安全距离内,车联网技术让车辆交通行人这些角色融为一个瑞士女主持人想感染病毒各种舔,终究如愿了!网友咎由自取新型冠状病毒正以可怕的速度席卷欧洲个主要国家。欧洲个国家的人民一直在倡导自由。他们的行为也很大胆。他们总是会做出许多我们的人民无法理解的大胆举动。例如,当流行病爆发时,欧洲仍有许多苹果反击华为,iPhoneXR猛降2600块,网友犹豫了虽说在高端手机市场,华为一直在致力于产品技术领域的创新,并且把技术成果应用到自家的高端手机上,因此iPhone的地位受到了不小的挑战。最近华为和苹果高端手机价格领域展开了竞争,你方用了一周vivoX60,谈谈最真实的优缺点手机市场的竞争从来没有消退过,一直很激烈。不是你方唱罢我登台,就是互相较劲寸步不让。vivo专注于线下市场的开发,一直以来也是vivo的主要竞争手段之一。而这些年,凭借技术的进步和这四款华为手机已经过时,贪便宜入手要吃亏依靠自研的芯片提升产品核心竞争力,凭借出色的外观设计和质感来表现审美,再加上在拍照上的优势,华为的Mate系列和P系列凭借这三板斧牢牢占据了高端手机市场,也把华为打造成为了国产高端跑步真的会猝死吗?如果跑步时身体出现这些症状,赶紧停下跑步会猝死?相信大部分跑者都没有认真考虑过这个问题,但是它的的确确发生了。近几年经常看到网上出现跑步猝死的新闻,比如有一位资深的跑友,早上晨跑时就猝死了。后来其他跑友介绍他有高血压鳄鱼皮版iPhone12上手这质感,连保时捷设计都不香了虽然人无高低贵贱之分,但是我们总是不可避免的通过一个人的穿着打扮车子手机和配饰等等,来揣摩判断一个人的身份和地位,尤其是在春节走亲访友期间,通过上述这些外在的东西,就能大致对于对方