mysql怎么让字段从1开始自增?

mysql怎么让字段从1开始自增?

要确保一个 AUTO_INCREMENT 字段从1开始自增,你需要在创建表的时候指定 AUTO_INCREMENT 的起始值为1

或者在表创建之后手动设置 AUTO_INCREMENT 的值。

1.创建表时指定

当你创建表的时候,可以直接指定 AUTO_INCREMENT 的起始值为1:

sql 复制代码
CREATE TABLE example_table (
    id INT NOT NULL AUTO_INCREMENT,
    name VARCHAR(100),
    created_at TIMESTAMP,
    PRIMARY KEY (id)
) AUTO_INCREMENT = 1;

这里的AUTO_INCREMENT = 1 确保了 id 字段的第一个值将从1开始。

2.在表创建之后手动设置

如果你的表已经创建好了,并且你想要确保 AUTO_INCREMENT 从1开始,

你可以使用 ALTER TABLE 语句来设置 AUTO_INCREMENT 的值:

sql 复制代码
ALTER TABLE example_table AUTO_INCREMENT = 1;

我的表面是tbl_book,我是这样写的

sql 复制代码
ALTER TABLE tbl_book AUTO_INCREMENT = 1;

注意事项

如果表中已经有数据,并且已经有了一些非连续的 id 值,设置 AUTO_INCREMENT 为1可能会导致新的 id 与旧的数据冲突。你应该确保所设置的新起始值不会与现有的任何 id 冲突。

效果

查看当前的 AUTO_INCREMENT 值

你还可以使用以下命令来查看当前的 AUTO_INCREMENT 值:

sql 复制代码
SHOW TABLE STATUS LIKE 'example_table';

我的表面是tbl_book,我是这样写的

sql 复制代码
SHOW TABLE STATUS LIKE 'tbl_book';

运行结果看下图

这将返回一个包含表状态信息的结果集,其中 Auto_increment 字段将显示当前的 AUTO_INCREMENT 值。

重置 AUTO_INCREMENT

如果你·删除了表中的最后一个行·,

或者执行了 TRUNCATE TABLE

MySQL 会重置AUTO_INCREMENT 的计数器。为了避免这种情况,

可以使用 DELETE 代替 TRUNCATE

并且在删除后手动设置 AUTO_INCREMENT 的值。

相关推荐
倔强的石头_4 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北1 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12023 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端