乐趣区

关于java:面试突击59一个表中可以有多个自增列吗

自增列可应用 auto_increment 来实现,当一个列被标识为 auto_increment 之后,在增加时如果不给此列设置任何值,或给此列设置 NULL 值时,那么它会应用自增的规定来填充此列。

PS:本文以下内容基于 MySQL InnoDB 数据库引擎。

默认状况下自增列的值为 1,每次递增 1,比方以下建表 SQL:

create table tab_incre(
    id int primary key auto_increment,
    name varchar(250) not null
);


咱们在增加时,不给自增列 id 设置任何值,它的执行后果如下:

从上述后果能够看出自增列默认值为 1,每次递增 1。

1. 手动指定自增值

在创立表的时候能够手动指定自增值,如果不指定自增值,那么它默认会应用 1 作为自增值,手动指定自增值的 SQL 命令如下:

create table tab_incre(
    id int primary key auto_increment,
    name varchar(250) not null
) auto_increment=50;


应用“show create table table_name”能够查看表中自增列的自增列值,如下图所示:

此表的自增值为 50,咱们也能够创立一条数据来验证一下自增值是否为 50,如下图所示:

2. 手动批改自增值

当表创立之后,咱们也能够通过 alter 命令来批改自增列的值,它的批改命令如下:

alter table table_name auto_increment=n;

如果要将 tab_incre 表中的自增值批改为 100,可应用以下 SQL 来实现:

注意事项

当咱们试图将自增值设置为比自增列中的最大值还要小的值的时候,自增值会主动变为自增列的最大值 +1 的值,如下图所示:

3. 一个表能够有多个自增列吗?

一个表中只能有一个自增列 ,这和一个表只能有一个主键的规定相似,当咱们尝试给一个表增加一个自增列时,能够失常增加胜利,如下图所示:

当咱们尝试给一个表增加多个自增列时,会提醒只能有一个自增列的报错信息,如下图所示:

4. 其余注意事项

除了一个表只能增加一个自增列之外,自增列还须要留神以下两个问题。

4.1 自增列只能为整数类型

自增列的字段类型只能为整数类型(TINYINT、SMALLINT、INT、BIGINT 等),如下图所示:

当咱们应用其余类型来作为自增列的数据类型时,会提醒如下谬误:

4.2 必须配合 key 一起应用

auto_increment 必须配合 key 一起应用,这个 key 能够是 primary key 或 foreign key,如果没有 key 就会报错,如下所示:

PS:auto_increment 也能够配合惟一束缚 unique 一起应用。

总结

自增列的值默认是 1,每次递增 1,但也能够在创立表的时候手动指定自增值,当然在非凡状况下咱们在表被创立之后,也能够通过 alter 批改自增值。一个表中只能有一个自增列,就像一个表中只能有一个主键一样,如果设置多个自增列,那么 SQL 执行就会报错。除此之外还要留神自增列应该为整数类型,且 auto_increment 须要配合 key 一起应用,这个 key 能够是 primary key 或 foreign key。

是非审之于己,毁誉听之于人,得失安之于数。

公众号:Java 面试真题解析

面试合集:https://gitee.com/mydb/interview

退出移动版