没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
试读
3页
下面这几个小问题都是基于 InnoDB 存储引擎的。 1. ID最大的记录删除后,新插入的记录ID是什么 例如当前表中有ID为1,2,3三条记录,把3删除,新插入记录的ID从哪儿开始? 答案: 从4开始。 实验 创建表 tb0,ID自增: create table tb0(id int unsigned auto_increment primary key); 插入3条记录: insert into tb0 values(null); 删除ID为3的记录: delete from tb0 where id=3 查看当前自增值: show create table tb0; # 结
资源详情
资源评论
资源推荐
关于关于MySQL自增自增ID的一些小问题总结的一些小问题总结
下面这几个小问题都是基于 InnoDB 存储引擎的。
1. ID最大的记录删除后,新插入的记录最大的记录删除后,新插入的记录ID是什么是什么
例如当前表中有ID为1,2,3三条记录,把3删除,新插入记录的ID从哪儿开始?
答案: 从4开始。
实验实验
创建表 tb0,ID自增:
create table tb0(id int unsigned auto_increment primary key);
插入3条记录:
insert into tb0 values(null);
删除ID为3的记录:
delete from tb0 where id=3
查看当前自增值:
show create table tb0;
# 结果
CREATE TABLE `tb0` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=latin1
自增ID为4,删除ID最大的记录并不影响自增ID的值。
2. MySQL 重启后自增重启后自增ID从哪儿开始从哪儿开始
例如当前表中有ID为1,2,3三条记录,把3删除,重启MySQL,新插入记录的ID从哪儿开始?
很多人会认为从4开始,实际是从3开始。
因为InnoDB的自增值是记录在内存的,不是记录在数据文件的。
重启后,会把 当前最大ID + 1 作为起始值。
实验实验
创建表 tb1,ID自增:
create table tb1(id int unsigned auto_increment primary key);
添加3条数据记录:
insert into tb1 values(null);
删除ID为3的记录:
delete from tb1 where id=3
通过上一个问题,我们知道,此时自增ID值为4。
重启MySQL。
查看当前的自增值:
show create table tb1;
weixin_38621386
- 粉丝: 5
- 资源: 896
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0