MySQL 中自定义步长

### 简介

我们知道在 MySQL 中创建表时可以使用 auto_increment 关键字来表示自增序列,例如:

use test;
create tb_incre1 (
id int not null auto_increment primary key,
name varchar(10) not null default 'xxx'
);

该自增选项默认开始于 1,每次插入时步进序列也为 1
参考官方文档: MySQL :: MySQL 8.0 Reference Manual :: 3.6.9 Using AUTO_INCREMENT

### 进阶需求

除了使用 auto_increment 作为自动增加的序列外,还可以指定自增序列的起始值、步进长度。
例如,我不希望MySQL中的初始值为1、我想让每次插入时的步长为5。此时可以使用全局变量 @@auto_increment_increment@@auto_increment_offset来实现。

简单来说:

### 初始化示例

create database db1;
use db1;
create table t1 (
id int not null auto_increment primary key,
name varchar(20) not null default ''
);
set @@global.auto_increment_increment=3;

### 数据插入测试

mysql> insert into t1 (name) values ('zhangsan');
Query OK, 1 row affected (0.00 sec)
mysql> insert into t1 (name) values ('zhangsan1');
Query OK, 1 row affected (0.00 sec)
mysql> insert into t1 (name) values ('zhangsan2');
Query OK, 1 row affected (0.00 sec)
mysql> insert into t1 (name) values ('zhangsan3');
Query OK, 1 row affected (0.00 sec)
mysql> insert into t1 (name) values ('zhangsan4');
Query OK, 1 row affected (0.00 sec)
mysql> select * from t1;
+----+-----------+
| id | name |
+----+-----------+
| 2 | zhangsan |
| 5 | zhangsan1 |
| 8 | zhangsan2 |
| 11 | zhangsan3 |
| 14 | zhangsan4 |
+----+-----------+
5 rows in set (0.00 sec)
mysql>
  • 7
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值