开发者

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

开发者 https://www.devze.com 2024-08-13 12:03 出处:网络 作者: Java-Talk
目录mysql变更自增主键id起始值account 库 user 表结构获取自增id字段的下一个值修改自增id字段的初始值其他 SQL 说明mysql设置主键自动增长起始值实现目标方案1)方案2)3)如果表已有数据 truncate之后设置4)如果
目录
  • mysql变更自增主键id起始值
    • account 库 user 表结构
    • 获取自增id字段的下一个值
    • 修改自增id字段的初始值
    • 其他 SQL 说明
  • mysql设置主键自动增长起始值
    • 实现目标
    • 方案1)
    • 方案2)
    • 3)如果表已有数据 truncate之后设置
    • 4)如果表已有数据 delete from之后设置
  • 总结

    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

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

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

    方法一:

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

    得到如下结果:

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

    方法二:

    SHOW table STAidQRHRKCQTUS like 'user'

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

    修改自增id字段的初始值

    alter table user AUTO_INCREMENT=500

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

    其他 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` androidAUTO_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`;
    
    CREphpATE 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 CpythonHARSET=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

    总结

    以上为个人经js验,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。

    0

    精彩评论

    暂无评论...
    验证码 换一张
    取 消