《MySQL删除数据的三种方式》中的作业题,99%的人答错,有点出乎意料。画外音:评论中不乏嘲笑知识点简单的小伙伴。
专注于为中小企业提供网站制作、成都网站设计服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业昭化免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千余家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。
今天简单说下作业题中的答案,以及知识点。
作业题是这样的:
实验步骤如上图:
画外音: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;
请问:
知其然,更知其底层所以然。
当前标题:MySQL自增ID,居然大部分人都搞错了!?
URL标题:http://www.mswzjz.cn/qtweb/news31/280531.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能