【Mysql 学习】自动增长列

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

--对于innodb表,自动增长列必须是索引。如果是组合索引,也必须是前导列。
mysql> create table innodb_auto
    -> ( id1 int not null auto_increment,
    -> id2 int not null,
    -> val varchar(10),
    -> index(id2,id1)
    -> ) engine=innodb;
ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key
--但是对于myisam表,自动增长列可以是组合索引的其他列。这样插入记录后,自动增长列是按照组合索引的前面几列进行排序后递增的。如下实验:
--创建一个myisam表
mysql> create table myisam_auto
    -> ( id1 int not null auto_increment,
    -> id2 int not null,
    -> val varchar(10),
    -> index(id2,id1)
    -> ) engine=myisam;
Query OK, 0 rows affected (0.11 sec)

mysql> insert into myisam_auto(id2,val) values(2,'2'),(3,'3'),(4,'4'),(5,'5'),(2,'2'),(3,'3'),(4,'4');
Query OK, 7 rows affected (0.00 sec)
Records: 7  Duplicates: 0  Warnings: 0

mysql> select * from myisam_auto;
+-----+-----+------+
| id1 | id2 | val  |
+-----+-----+------+
|   1 |   2 | 2    |
|   1 |   3 | 3    |
|   1 |   4 | 4    |
|   1 |   5 | 5    |
|   2 |   2 | 2    |
|   2 |   3 | 3    |
|   2 |   4 | 4    |
+-----+-----+------+
7 rows in set (0.00 sec)

mysql> insert into myisam_auto(id2,val) values(3,'3'),(4,'4');
Query OK, 2 rows affected (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 0

mysql> select * from myisam_auto;
+-----+-----+------+
| id1 | id2 | val  |
+-----+-----+------+
|   1 |   2 | 2    |
|   1 |   3 | 3    |
|   1 |   4 | 4    |
|   1 |   5 | 5    |
|   2 |   2 | 2    |
|   2 |   3 | 3    |
|   2 |   4 | 4    |
|   3 |   3 | 3    |
|   3 |   4 | 4    |
+-----+-----+------+
9 rows in set (0.00 sec)
由以上实验可以看出对于组合索引 id1,id2 插入一些数据,自动组合列是根据组合索引的第一列d2 进行排序后递增的。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
存储 关系型数据库 MySQL
|
1月前
|
SQL 存储 关系型数据库
【MySQL 数据库】11、学习 MySQL 中的【锁】
【MySQL 数据库】11、学习 MySQL 中的【锁】
76 0
|
存储 关系型数据库 MySQL
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL 数据库】4、MySQL 事务学习
【MySQL 数据库】4、MySQL 事务学习
44 0
|
16天前
|
SQL 存储 关系型数据库
6本值得推荐的MySQL学习书籍
本文是关于MySQL学习书籍的推荐,作者在DotNetGuide技术社区和微信公众号收到读者请求后,精选了6本值得阅读的MySQL书籍,包括《SQL学习指南(第3版)》、《MySQL是怎样使用的:快速入门MySQL》、《MySQL是怎样运行的:从根儿上理解MySQL》、《深入浅出MySQL:数据库开发、优化与管理维护(第3版)》以及《高性能MySQL(第4版)》和《MySQL技术内幕InnoDB存储引擎(第2版)》。此外,还有12本免费书籍的赠送活动,涵盖《SQL学习指南》、《MySQL是怎样使用的》等,赠书活动有效期至2024年4月9日。
|
21天前
|
SQL 关系型数据库 MySQL
轻松入门MySQL:深入学习数据库表管理,创建、修改、约束、建议与性能优化(3)
轻松入门MySQL:深入学习数据库表管理,创建、修改、约束、建议与性能优化(3)
|
2月前
|
SQL 关系型数据库 MySQL
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
MySQL技能完整学习列表10、数据导入和导出——1、数据导入(LOAD DATA, mysqldump)——2、数据导出(SELECT ... INTO OUTFILE, mysqldump)
49 0
|
2月前
|
存储 SQL 关系型数据库
MySQL技能完整学习列表7、存储过程和函数——1、存储过程(Stored Procedures)的创建和执行——2、函数(Functions)的创建和使用
MySQL技能完整学习列表7、存储过程和函数——1、存储过程(Stored Procedures)的创建和执行——2、函数(Functions)的创建和使用
35 0
|
1天前
|
存储 SQL 关系型数据库
MySQL学习手册(第一部分)
mysql日常使用记录
27 0
|
存储 SQL 关系型数据库