MySQL自增ID,居然大部分人都搞错了

发表于:2022-5-20 09:26

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:架构师之路    来源:架构师之路

  《MySQL删除数据的三种方式》中的作业题,99%的人答错,有点出乎意料。画外音:评论中不乏嘲笑知识点简单的小伙伴。
  今天简单说下作业题中的答案,以及知识点。
  作业题是这样的:
  实验步骤如上图:
  第一步:建表,设定自增列;
  第二步:指定id=1插入,锚定第一行是id是1;
  第三步:不指定id,依赖自增机制,插入3行;画外音:此时id应该变为2,3,4了?
  第四步:delete删除所有记录;画外音:坑就容易出在这里。
  第五步:指定id=0插入;
  第六步:指定id=1插入;
  第七步:不指定id,依赖自增机制,插入1行;
  请问,此时表中的三行记录,id分别是多少?
  知识点一:delete数据后,自增列计数不会从头开始。
  画外音:truncate数据后,自增列计数会从头开始。
  因此,在第四步delete删除所有4条记录后,自增列计数,并不会重新归0,也就是说,下一条insert的记录,自增列的值会是5。
  知识点二:含自增列的表,插入时可以手动指定自增列的值,但不能与已有值冲突,也可以使用系统默认自增列的值。
  因此,第五、六、七步都是允许的:
  insert (0, '000')
  insert (1, '111')
  insert ('222')

  知识点三:如果手动指定自增列的值是0或者NULL,MySQL会视为无效,并使用系统默认自增列的值。
  也就是说,第五步insert (0, '000') 又或者 insert (NULL, '000')都会被MySQL视为:
  insert ('000')

  即,实际插入到表中的记录是
  (5, '000')

  第六步insert (1, '111')没有问题
  实际插入的也是
  (1, '111')

  知识点四:如果使用系统默认自增列的值,会从当前最大值开始往后增加。
  也就是说,第七步insert ('222'),会使用默认值6,而不是2。
  实际插入的是
  (6, '222')
 
  故,实验结果,最终的三行记录是:
  5,000
  1,111
  6,222

  你答对了吗?
  为了巩固下上面的知识点,咱们一起来复习一下:
  drop table t1;
  create table t1(
      id int not null auto_increment,
      name varchar(10) unique,
      count int default 0,
      primary key(id),
      index(name)
  )engine=innodb;
  insert into t1(id, name) values(1, "shenjian");
  insert into t1(id, name) values 
  (111, "111"),(NULL, "abc"),(222, "222"),(NULL,"xyz");

  请问,执行结束后id分别是多少呢?
  答案:
  (1, 'shenjian')
  (111, '111')    // 允许指定值
  (112, 'abc')    // 忽略NULL,从最大值开始增
  (222, '222')    // 允许指定值
  (223, 'xyz')    // 忽略NULL,从最大值开始增

  上题如果继续执行以下语句:
  insert into t1(name)values("shenjian"),("aaa"),("bbb")
  on duplicate key update count=100;

  请问:
  ·会不会执行报错?
  · 如果报错,为什么呢?
  · 如果不报错,得到的数据是什么呢?
  知其然,更知其底层所以然。

  本文内容不用于商业目的,如涉及知识产权问题,请权利人联系51Testing小编(021-64471599-8017),我们将立即处理
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号