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 的值。

相关推荐
jason.zeng@15022075 分钟前
my.cnf详解
运维·数据库·adb
百***62859 分钟前
MySQL 常用 SQL 语句大全
数据库·sql·mysql
2501_9159184110 分钟前
移动端 HTTPS 抓包实战,多工具组合分析与高效排查指南
数据库·网络协议·ios·小程序·https·uni-app·iphone
百***69716 分钟前
MySQL数据库(SQL分类)
数据库·sql·mysql
只因在人海中多看了你一眼29 分钟前
B.40.5.1-数据库基础与核心原理
数据库
2503_9284115643 分钟前
11.11 Express-generator和文件上传和身份认证
数据库·node.js·express
长沙红胖子Qt1 小时前
关于 mariadb开源数据库忘记密码 的解决方法
数据库·mariadb
二进制的Liao1 小时前
【编程】脚本编写入门:从零到一的自动化之旅
数据库·python·算法·自动化·bash
影子24011 小时前
oralce创建种子表,使用存储过程生成最大值sql,考虑并发,不考虑并发的脚本,plsql调试存储过程,java调用存储过程示例代码
java·数据库·sql
武子康1 小时前
Java-172 Neo4j 访问方式实战:嵌入式 vs 服务器(含 Java 示例与踩坑)
java·服务器·数据库·sql·spring·nosql·neo4j