MySql8自动递增一直显示0

版本:MySQL8.0.25

我新建一张测试表test:

CREATE TABLE `test` (
  `id` int unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB;

然后我往里面插入数据:

INSERT INTO `rrweb`.`test`(`name`) VALUES ('a');
INSERT INTO `rrweb`.`test`(`name`) VALUES ('a');
INSERT INTO `rrweb`.`test`(`name`) VALUES ('b');

MySql8自动递增一直显示0

但是在navicat上的显示:

MySql8自动递增一直显示0

一直是0,不知道是平台问题还是mysql哪边配置的不对。其他MySQL5.6的表是没有这种情况的。

《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 15

是不是navicat的问题?用命令行看一下呢?

6天前 评论
bluememory (楼主) 6天前

你用navicat往表里面加数据,看看id对不对,我感觉是navicat的锅,看看navicat版本是不是太老了

6天前 评论
bluememory (楼主) 6天前
陈先生

刷新一下你的表,然后在看表详情。

6天前 评论
bluememory (楼主) 6天前

把表的自增设置成1开始

CREATE TABLE `test` (
  `id` int unsigned NOT NULL AUTO_INCREMENT,
  `name` varchar(255) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1  DEFAULT CHARSET=utf8mb4;
6天前 评论
bluememory (楼主) 5天前
陈先生

file

6天前 评论
haodudecao 5天前
陈先生 (作者) 4天前

那就是 navicat 版本太旧了,对 mysql8 的数据表信息解析不完全了,考虑升级下navicat

6天前 评论

用mysql cli查一下看一下

5天前 评论
黑将军

应该是Navicat问题

5天前 评论

因为mysql8比较新,有些版本会有兼容小bug,说下我之前遇到的,之前版本 12.1.12 ,mysql 8.0,我导出表sql结构,结果发现如果id是 UNSIGNED bigint,那么导出的 id 列,会丢失 AUTO_INCREMENT 的自增信息,后来我升级到 12.1.28 就不会了

5天前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!