MySQL的系统变量或会话变量auto_increment_increment(自增步长)和auto_increment_offset(自增偏移量)控制着数据表的自增列ID。
  
  mysql> show tables;
  
  Empty set (0.00 sec)
  
  mysql> CREATE TABLE `test_tb1` ( `id` int(4) NOT NULL AUTO_INCREMENT PRIMARY KEY, `name` varchar(20)) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  
  Query OK, 0 rows affected (0.16 sec)
  
  mysql> insert into test_tb1(name) values('Andy'),('Danny');
  
  Query OK, 2 rows affected (0.13 sec)
  
  Records: 2 Duplicates: 0 Warnings: 0
  
  mysql> select * from test_tb1;
  
  +----+-------+
  
  | id | name |
  
  +----+-------+
  
  | 1 | Andy |
  
  | 2 | Danny |
  
  +----+-------+
  
  2 rows in set (0.04 sec)
  
  mysql> show session variables like '%auto_incre%';
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 1 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.01 sec)
  
  mysql> set session auto_increment_increment=10;
  
  Query OK, 0 rows affected (0.00 sec)
  
  mysql> show session variables like '%auto_incre%'; -- 改变自增步长
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 10 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.01 sec)
  
  mysql> show global variables like '%auto_incre%'; -- 全局变量并没有变化
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 1 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.05 sec)
  
  mysql> truncate table test_tb1;
  
  Query OK, 0 rows affected (0.09 sec)
  
  mysql> insert into test_tb1(name) values('Andy'),('Bonny'),('Lisa'),('Jack'),('Robin');
  
  Query OK, 5 rows affected (0.06 sec)
  
  Records: 5 Duplicates: 0 Warnings: 0
  
  mysql> select * from test_tb1;
  
  +----+-------+
  
  | id | name |
  
  +----+-------+
  
  | 1 | Andy |
  
  | 11 | Bonny |
  
  | 21 | Lisa |
  
  | 31 | Jack |
  
  | 41 | Robin |
  
  +----+-------+
  
  5 rows in set (0.00 sec)
  
  获取指定数据表的下一个auto_increment自增值的两种方式:
  
  mysql> show table status \G
  
  *************************** 1. row ***************************
  
  Name: test_tb1
  
  Engine: InnoDB
  
  Version: 10
  
  Row_format: Dynamic
  
  Rows: 5
  
  Avg_row_length: 3276
  
  Data_length: 16384
  
  Max_data_length: 0
  
  Index_length: 0
  
  Data_free: 0
  
  Auto_increment: 51
  
  Create_time: 2018-12-19 14:43:53
  
  Update_time: 2018-12-19 14:54:23
  
  Check_time: NULL
  
  Collation: utf8_general_ci
  
  Checksum: NULL
  
  Create_options:
  
  Comment:
  
  1 row in set (0.00 sec)
  
  mysql> select auto_increment from information_schema.`TABLES` where table_name='test_tb1';
  
  +----------------+
  
  | auto_increment |
  
  +----------------+
  
  | 51 |
  
  +----------------+
  
  1 row in set (0.03 sec)
  
  auto_increment_increment和auto_increment_offset的取值范围: 1 ~ 65535,这个范围和自增列的值没关系,列的数据大小是对应的值类型控制的。
  
  mysql> set auto_increment_yongshiyule178.com increment=-1;
  
  Query OK, 0 rows affected, 1 warning (0.05 sec)
  
  mysql> show variables like '%auto_incre%'; -- 小于1时用默认最小值1
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 1 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.00 sec)
  
  mysql> set auto_increment_www.mcyllpt.com increment=65536;
  
  Query OK, 0 rows affected, 1 warning (0.00 sec)
  
  mysql> show variables like '%auto_incre%'; -- 大于65535时用默认最大值65536
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 65535 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.00 sec)
  
  mysql> truncate table test_tb1;
  
  Query OK, 0 rows affected (0.49 sec)
  
  mysql> insert into test_tb1(name) values('Andy'), ('Bonny'), ('Danny'), ('Jack'), ('Robin');
  
  Query OK, 5 rows affected (0.01 sec)
  
  Records: 5 Duplicates: 0 Warnings: 0
  
  mysql> select * from test_www.yigouyule2.cn tb1; -- 值可以大于65535
  
  +--------+-------+
  
  | id | name |
  
  +--------+-------+
  
  | 1 | Andy |
  
  | 65536 | Bonny |
  
  | 131071 | Danny |
  
  | 196606 | Jack |
  
  | 262141 | Robin |
  
  +--------+-------+
  
  5 rows in set (0.00 sec)
  
  mysql> truncate table test_tb1;
  
  Query OK, 0 rows www.michenggw.com affected (0.06 sec)
  
  mysql> insert into test_tb1(id, name) values(-3, 'Andy'), (-2, 'Bonny'), (-1, 'Danny');
  
  Query OK, 3 rows affected (0.06 sec)
  
  Records: 3 Duplicates: 0 Warnings: 0
  
  mysql> select * from test_tb1; -- 值可以小于1
  
  +----+-------+
  
  | id | name |
  
  +----+-------+
  
  | -3 | Andy |
  
  | -2 | Bonny |
  
  | -1 | Danny |
  
  +----+-------+
  
  3 rows in set (0.00 sec)
  
  全局(global)与会话(session)自增属性,会话针对当前连接的所有操作,全局变量会在新的连接会话中生效。
  
  mysql> show global variables like 'auto_incre%'; -- 全局的自增属性值
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 1 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.01 sec)
  
  mysql> show variables like 'auto_incre%'; -- 会话的自增属性值,同show session variables like 'auto_incre%';
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 65535 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.00 sec)
  
  mysql> set global auto_increment_increment=10;
  
  Query OK, 0 rows affected (0.00 sec)
  
  mysql> show variables like 'auto_incre%';
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 65535 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.01 sec)
  
  mysql> show global variables like 'auto_incre%';
  
  +--------------------------+-------+
  
  | Variable_name | Value |
  
  +--------------------------+-------+
  
  | auto_increment_increment | 10 |
  
  | auto_increment_offset | 1 |
  
  +--------------------------+-------+
  
  2 rows in set (0.00 sec)

MySQL自增属性auto_increment_increment和auto_increment_offset的更多相关文章

  1. Mysql设置auto_increment_increment和auto_increment_offset

    查看与设置: show variables like '%auto_inc%'; show session variables like '%auto_inc%'; -- //session会话变量 ...

  2. MySQL系统变量auto_increment_increment与auto_increment_offset学习总结

    在MySQL中,系统变量auto_increment_increment与auto_increment_offset是与自增列相关的两个参数变量.在官方文档中,将其划分为Replication Mas ...

  3. MySQL auto_increment_increment 和 auto_increment_offset

    参考这一篇文章:(不过我对这一篇文章有异议) http://blog.csdn.net/leshami/article/details/39779509 1:搭建测试环境 create table t ...

  4. mysql为字段添加或删除自增属性

    删除自增属性: ALTER TABLE `members` CHANGE uid uid INT(10) UNSIGNED NOT NULL ; 添加自增属性: ALTER TABLE `member ...

  5. MySql id 设定为主键不自增后,再给 sort 字段增加自增属性

    需求 id 已经被设置为主键,但是没有给它设置 自增 属性.sort 起到一个排序的作用,需要给它设置一个 自增 属性 加自增属性的前提 表中的属性没有增加自增 赋予自增属性的字段,必须带有 索引 S ...

  6. mysql 的增删改查

    数据库的基本流程就是先看你的数据库中的库都是哪些:show databases; 然后再进入相应的库进行操作  :  use+进入的库/表 切换路径 查看这个库内的所有的表: show tabales ...

  7. Java连接MySQL数据库增删改查通用方法

    版权声明:本文为博主原创文章,未经博主允许不得转载. Java连接MySQL数据库增删改查通用方法 运行环境:eclipse+MySQL 以前我们Java连接MySQL数据库都是一个数据库写一个类,类 ...

  8. Asp.Net操作MySql数据库增删改查

    Asp.Net操作MySql数据库增删改查,话不多说直接步入正题.git源码地址:https://git.oschina.net/gxiaopan/NetMySql.git  1.安装MySQL数据库 ...

  9. mybatis的执行流程 #{}和${} Mysql自增主键返回 resultMap 一对多 多对一配置

    n Mybatis配置 全局配置文件SqlMapConfig.xml,配置了Mybatis的运行环境等信息. Mapper.xml文件即Sql映射文件,文件中配置了操作数据库的Sql语句.此文件需要在 ...

随机推荐

  1. webpack3构建全面提速优化vue-cli

    前言 伴随着vue的全球化,各种vue的组件框架越来越完善,从早期的element-ui到vux,iview等越来越多高质量的项目,使用vue进行前端构建已然是一件工程化,模块化,敏捷化的事情 在这其 ...

  2. Docker(三):部署软件

    Docker的镜像文件可以在镜像仓库中进行搜索. 部署软件目录导航: 常用命令 部署 Tomcat 部署 MySQL 部署 Oracle 常用命令 docker的常用命令如下: docker -v , ...

  3. Asp.Net Core使用Nginx实现反向代理

    ---恢复内容开始--- 前两篇文章介绍了使用Docker作为运行环境,用Nginx做反向代理的部署方法,这篇介绍一下使用Nginx配合.Net Core运行时直接在Liunx上裸奔的方法. 一.安装 ...

  4. haystack+Elasticsearch搜素引擎

    搜索引擎原理 通过搜索引擎进行数据查询时,搜索引擎并不是直接在数据库中进行查询,而是搜索引擎会对数据库中的数据进行一遍预处理,单独建立起一份索引结构数据. 我们可以将索引结构数据想象成是字典书籍的索引 ...

  5. ECSHOP和SHOPEX快递单号查询德邦插件V8.6专版

    发布ECSHOP说明: ECSHOP快递物流单号查询插件特色 本ECSHOP快递物流单号跟踪插件提供国内外近2000家快递物流订单单号查询服务例如申通快递.顺丰快递.圆通快递.EMS快递.汇通快递.宅 ...

  6. springboot学习(2)

    WebMvcConfigurerAdapter 在springboot2.0及以上版本过时问题 WebMvcConfigurerAdapter已经过时,替代方案: 1 实现 WebMvcConfigu ...

  7. python面向对象-cs游戏示例

    #!/usr/local/bin/python3 # -*- coding:utf-8 -*- class Role(object): n = 123 # 类变量 name = "我是类na ...

  8. 一笔画问题 南阳acm42(貌似没用到什么算法)

    一笔画问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下 ...

  9. CUBLAS基础实验

    一.概述 最近在试图进行cuda并行编程,目标是编写一段矩阵计算代码,将计算结果存储进入GPU的缓冲区当中,并在达到某些要求后强制刷新缓冲区,取得计算结果. 但是考虑时间紧任务重的状况和实际的性能要求 ...

  10. 剑指offer题目系列二

    本篇延续上一篇,介绍<剑指offer>第二版中的四个题目:从尾到头打印链表.用两个栈实现队列.旋转数组的最小数字.二进制中1的个数. 5.从尾到头打印链表 题目:输入一个链表的头结点,从尾 ...