mysql如何变更自增主键id起始值

 更新时间:2024年08月05日 17:06:47   作者:Java-Talk  
这篇文章主要介绍了mysql如何变更自增主键id起始值问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mysql变更自增主键id起始值

account 库 user 表结构

CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID',
  `name` varchar(50) NOT NULL COMMENT '用户名',
  `age` int(11) NOT NULL COMMENT '年龄',
  `create_datetime` datetime NOT NULL COMMENT '创建时间',
  `update_datetime` datetime NOT NULL COMMENT '更新时间',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8

获取自增id字段的下一个值

方法一:

SELECT auto_increment FROM information_schema.tables where table_schema="account" and table_name="user";

得到如下结果:

方法二:

SHOW table STATUS like 'user'

修改自增id字段的初始值

alter table user AUTO_INCREMENT=500

其他 SQL 说明

  • 1 select last_insert_id() from user

在使用 Insert 语句后,紧接着使用 select last_insert_id() 才有效,在没有使用过 Insert 语句的情况下,查询返回的结果为0。

  • 2 select max(id) from user

如果手动删除了最新的数据,使用 max(id)查询的结果是当前剩下数据中最大的记录,而新插入数据则不一定从这个数字开始计数。

mysql设置主键自动增长起始值

实现目标

mysql下将自增主键的值,从10000开始,即实现自增主键的种子为10000。

方案1)

使用alter table `tablename` AUTO_INCREMENT=10000

创建自增主键之后,使用alter table `tablename` AUTO_INCREMENT=10000实现修改表起始值。

drop table if exists `trace_test`;

CREATE TABLE `trace_test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;

alter table `trace_test` AUTO_INCREMENT=10000;

insert into `trace_test`(`name`)values('name2');
select * from `trace_test`;
Result:

id     name
10000  name2

方案2)

创建表时设置AUTO_INCREMENT 10000参数

drop table if exists `trace_test`;

CREATE TABLE `trace_test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT 10000 DEFAULT CHARSET=utf8 ;

insert into `trace_test`(`name`)values('name2');
select * from `trace_test`;
Result:

id     name
10000  name2

3)如果表已有数据 truncate之后设置

auto_increment=10000,可行。

drop table if exists `trace_test`;

CREATE TABLE `trace_test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;

insert into `trace_test`(`name`)values('name1');
select * from `trace_test`;

truncate table `trace_test`;
alter table `trace_test` AUTO_INCREMENT=10000;

insert into `trace_test`(`name`)values('name2');
select * from `trace_test`;
Result1:

id     name
10000  name
Result2:

id     name
10000  name2

4)如果表已有数据 delete from之后设置

auto_increment=10000,可行。

drop table if exists trace_test;

CREATE TABLE trace_test (
  id int(20) NOT NULL AUTO_INCREMENT,
  name varchar(255) DEFAULT NULL,
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ;

insert into trace_test(name)values('name1');
select * from trace_test;

delete from `trace_test`;

alter table trace_test AUTO_INCREMENT=10000;

insert into trace_test(name)values('name2');
select * from trace_test;
Result1:

id     name
10000  name
Result2:

id     name
10000  name2

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL5.7.44-winx64版本Windows Server下载安装过程

    MySQL5.7.44-winx64版本Windows Server下载安装过程

    本文详细介绍了如何下载、安装和配置MySQL 5.7.44的步骤,包括设置环境变量、修改配置文件和密码,以及如何修改默认端口
    2025-12-12
  • MySQL Proxy的安装及基本命令使用教程

    MySQL Proxy的安装及基本命令使用教程

    这篇文章主要介绍了MySQL Proxy的安装及基本命令使用教程,MySQL Proxy通常被用作实现读写分离,需要的朋友可以参考下
    2015-12-12
  • mysql的约束及实例分析

    mysql的约束及实例分析

    这篇文章主要介绍了mysql的约束及实例分析,真正约束字段的是数据类型,但是数据类型约束很单一,需要有一些额外的约束,更好的保证数据的合法性,从业务逻辑角度保证数据的正确性,需要的朋友可以参考下
    2023-07-07
  • MySQL进阶之索引

    MySQL进阶之索引

    索引就是一种数据结构,这种结构类似,链表,树等等。但是比它们要复杂的多,索引(index)是帮助MySQL高效获取数据的数据结构(有序),本文详细介绍了MySQL索引,感兴趣的同学可以参考阅读
    2023-04-04
  • MySQL基础之MySQL 5.7 新增配置

    MySQL基础之MySQL 5.7 新增配置

    mysql数据库性能非常高,运行速度非常快,接下来通过本文给大家介绍MySQL 5.7 新增配置,非常不错,具有参考借鉴价值,感兴趣的朋友一起看看吧
    2016-09-09
  • 使用Navicat连接远程服务器中在docker中运行的MySQL数据库全过程

    使用Navicat连接远程服务器中在docker中运行的MySQL数据库全过程

    文章介绍了如何使用Navicat客户端连接到运行在Docker容器中的MySQL数据库,首先,需要获取服务器的公网IP和MySQL容器的IP地址,然后,在Navicat中配置SSH连接到服务器,并测试连接,接着,配置MySQL连接参数,并再次测试连接,最后,确认连接成功
    2026-03-03
  • mysql添加enum类型的字段实现

    mysql添加enum类型的字段实现

    Enum类型它允许我们在一个有限的选项列表中选择一个值,本文主要介绍了mysql添加enum类型的字段实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01
  • mysql explain中key_len的含义以及计算方法

    mysql explain中key_len的含义以及计算方法

    通常在优化SQL查询的时候,我们都会使用explain分析SQL执行计划,下面这篇文章主要给大家介绍了关于mysql explain中key_len的含义以及计算方法的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-03-03
  • mysql中包含查询的五种方法总结

    mysql中包含查询的五种方法总结

    这篇文章主要给大家介绍了关于mysql中包含查询的五种方法, 在MySQL中,包含语句是一种用来包含其他查询语句的语句,通常用在WHERE语句中,需要的朋友可以参考下
    2023-08-08
  • MySQL入门实战:视图+用户权限管理使用方法(图文+代码)

    MySQL入门实战:视图+用户权限管理使用方法(图文+代码)

    本文详细介绍了MySQL的视图和用户权限管理,视图是虚拟表,不存储数据,数据来源于基表,视图和基表数据双向联动,用户管理与权限控制方面,最小权限原则、登录限制、禁止root远程登录和按业务分用户是生产环境的最佳实践,正确总结了视图和用户管理的核心知识点
    2026-04-04

最新评论