史上最简单的 MySQL 教程(十五)「列属性 之 自动增长」

温馨提示:本系列博文已经同步到 GitHub,地址为「mysql-tutorial」,欢迎感兴趣的童鞋StarFork,纠错。

自动增长

自动增长:auto_increment当对应的字段,不给值,或者是默认值,或者是null的时候,就会自动的被系统触发,系统会从当前字段中取已有的最大值再进行+1操作,得到新的字段值

自增长通过跟主键进行搭配使用,其特点为:

  • 任何字段要做自增长,前提其本身必须是一个索引,即key栏有值;
  • 自增长字段必须是数字(整型);
  • 每张表最多有一个自增长字段。

执行如下 SQL 语句,进行测试:

-- 自增长示例
create table my_auto(
	id int primary key auto_increment,
	name varchar(20) not null
)charset utf8;
1

使用自增长

当自增长给定的值为null或者默认值的时候,就是触发自动增长。

-- 触发自增长
insert into my_auto (name) values('Charies');
insert into my_auto values(null,'Guo');
insert into my_auto values(default,'ChariesGuo');
2

如上图所示,自增长的第一个元素默认是1,自增长每次都是自增1。此外,如果自增长对应的字段输入了值,那么自增长失效,但是下一次还是能够正确的自增长,即从取该字段的最大值+1.

那么,如何确定下一次自增长的数值是什么呢?简单,咱们可以通过查看表的创建语句看到。

-- 查看表的创建语句
show create table my_auto;
3

如上图所示,显然在咱们之前插入的 3 条记录之后,下一次自增长是4,符合咱们的结论。

修改自增长

自增长如果是涉及到字段改变,就必须先删除自增长,然后再增加自增长,因为每张表只能有一个自增长字段。

如果修改当前自增长字段已经存在的值,则只能修改比当前已有自增长字段中的最大值更大,不能更小,因为更小不生效。

  • 基本语法:alter table + 表名 + auto_increment = 值;

执行如下 SQL 语句,进行测试:

-- 修改自增长测试
alter table my_auto auto_increment = 2;
4

如上图所示,当咱们修改自增长小于当前自增长字段中的最大值时,虽然显示 SQL 语句执行成功,但实际上并没有修改成功。下面,在执行如下 SQL 语句,进行测试:

-- 修改自增长测试
alter table my_auto auto_increment = 5;
5

如上图所示,显然当咱们修改自增长大于当前自增长字段中的最大值时,修改成功。

在这里,咱们不妨思考一下,为什么自增长是从1开始呢?为什么每次都自增1呢?虽然现在咱们不知道是什么原因导致上面的表示形式,但是咱们知道,所有系统的表现(如字符集、校对集)都是由系统内部的变量进行控制的,因此咱们可以查看自增长对应的变量:

  • 基本语法:show variables like 'auto_increment%';
-- 查看自增长变量
show variables like 'auto_increment%';
6

如上图所示,其中auto_increment_increment表示步长auto_increment_offset表示初始值.

因此,咱们可以通过修改上面的两个变量实现不同的效果,但是需要注意的是:修改是会话级别,并且修改的是整个数据库,而不是单张表。

  • 基本语法:set auto_increment_increment = 值;

执行如下 SQL 语句,进行测试:

-- 修改自增长步长
set auto_increment_increment = 5;
insert into my_auto values (null,'Guobinhit');
7

如上图所示,咱们已经修改成功!接下来,执行如下 SQL 语句,进行测试:

-- 插入测试数据
insert into my_auto values (null,'Guobinhit');
insert into my_auto values (default,'Guobinhit');
8

如上图所示,咱们插入的第一个Guobinhitid值竟然是6,第二个Guobinhitid值倒是在6的基础上增加了511正常。这个现象产生的原因是:咱们之前的修改会导致系统产生一个误差,从初始值1开始计算加5,因此第一个Guobinhitid值是6.

不过说实话,修改自增长并没有什么实际的意义,在此只是想让大家知道:自增长的初始值和步长都是可以修改的而已。

删除自增长

自增长是字段的一个属性,因此可以通过modify来进行修改。想要删除自增长的话,只需要保证字段没有auto_increment即可

  • 基本语法:alter table + 表名 + modify + 字段 + 类型;

执行如下 SQL 语句,进行测试:

-- 删除自增长
alter table my_auto modify id int primary key;
9

如上图所示,呃,好吧,出错啦!这是因为表my_auto之前已经定义了主键,所以在执行上述 SQL 语句的时候,系统会认为咱们想要定义多个主键,自然就要报错啦!解决方法就是,去掉上述 SQL 语句中的primary key即可。

10

如上图所示,显然咱们已经成功删除自增长啦!


温馨提示:符号+表示连接的意思。


———— ☆☆☆ —— 返回 -> 史上最简单的 MySQL 教程 <- 目录 —— ☆☆☆ ————

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏技术小讲堂

Entity Framework4.3 Code-First基于代码的数据迁移讲解1.建立一个最初的模型和数据库   2.启动Migration(数据迁移)3.第一个数据迁移4.订制的数据迁移4.动态

前段时间一直在研究Entity Framework4,但是苦于没有找到我特别中意的教程,要么就是千篇一律的文章,而且写的特别简单,可以说,糟践了微软这么牛埃克斯...

3378
来自专栏学习力

《Java从入门到放弃》框架入门篇:hibernate中的多表对应关系

2167
来自专栏Danny的专栏

机房收费系统(VB.NET)——存储过程实战

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

1325
来自专栏python学习指南

Python爬虫(十一)_案例:使用正则表达式的爬虫

本章将结合先前所学的爬虫和正则表达式知识,做一个简单的爬虫案例,更多内容请参考:Python学习指南 现在拥有了正则表达式这把神兵利器,我们就可以进行对爬...

2025
来自专栏小灰灰

RabbitMQ基础教程之基本使用篇

1712
来自专栏木东居士的专栏

漫谈并发和并行:死磕哲学家进餐问题

2174
来自专栏海天一树

爬取百度百科5A景点摘要并实现分词

这里baike_spider.py用来爬取景点摘要,内容放在senic_spots目录中; cut_word.py用来分词,分词结果放在cut_word_res...

662
来自专栏积累沉淀

java事物处理

事物处理 什么是事物:个人认为事物,就是对数据库进行一组操作动作的集合,如果一组处理步骤要么全发生,要么一步也不执行,称这组处理步骤为一个事物。当所...

2239
来自专栏信安之路

HCTF2017的三个WriteUp

解决方法就是先 undefine 掉函数,再右键选择 Code,最后 Create function 就可以正常反编译了。

1020
来自专栏小狼的世界

Crontab中的除号(slash)到底怎么用?

crontab 是Linux中配置定时任务的工具,在各种配置中,我们经常会看到除号(Slash)的使用,那么这个除号到底标示什么意思,使用中有哪些需要注意的地方...

852

扫码关注云+社区