我在mysql中创建了一个新表,添加了一些行,但是show tables的auto\ u increment字段仍然返回null。
mysql手册上说:这个字段应该返回:“下一个自动增量值”
https://dev.mysql.com/doc/refman/8.0/en/show-table-status.html
我做错什么了?
如何正确找到下一个自动增量值?
复制步骤:
create table `test` (
`id` int(5) not null auto_increment,
`name` varchar(256),
PRIMARY KEY(`id`)
);
然后我跑:
show table status where name like 'test';
结果:
Name, Engine, Version, ..., Auto_increment, ...
'test', 'InnoDB', '10', ..., NULL, ...
然后我跑:
insert into test values(null,'name1');
insert into test values(null,'name2');
insert into test values(null,'name3');
编辑:-其他插入语法-
insert into test (name) values('name4');
insert into test (name) values('name5');
insert into test (name) values('name6');
获取表的状态
show table status where name like 'test';
结果
Name, Engine, Version, ..., Auto_increment, ...
'test', 'InnoDB', '10', ..., NULL, ...
表中的数据
select * from test;
结果:
1 name1
2 name2
3 name3
供参考:
SHOW VARIABLES LIKE "%version%";
结果:
'innodb_version', '8.0.12'
'protocol_version', '10'
'slave_type_conversions', ''
'tls_version', 'TLSv1,TLSv1.1,TLSv1.2'
'version', '8.0.12'
'version_comment', 'MySQL Community Server - GPL'
'version_compile_machine', 'x86_64'
'version_compile_os', 'Win64'
'version_compile_zlib', '1.2.11'
编辑:自动提交:
SHOW VARIABLES LIKE "autocommit";
结果:
'autocommit', 'ON'
编辑:
一段时间后,它自动开始工作。没有明确的理由让它开始工作。
1条答案
按热度按时间u59ebvdq1#
这是一个特点。。不是虫子。
将缓存表统计信息。要禁用缓存并始终使用最新版本,应将指示缓存清除持续时间的服务器变量更改为0:
在mysql 8.x中,此属性的默认值已更改为86400(24小时)
例子:
现在我们更改配置:
我们进行同样的测试: