如果我尝试从 AUTO_INCREMENT 列中删除 PRIMARY KEY 约束,会发生什么情况?
mysqlmysqli database
我们知道 AUTO_INCREMENT 列也必须具有 PRIMARY KEY 约束,因此当我们尝试从 AUTO_INCREMENT 列中删除 PRIMARY KEY 约束时,MySQL 会返回一条有关表定义错误的错误消息。下面的示例将演示它 −
示例
假设我们有 ‘Accounts’ 表,其描述如下 −
mysql> Describe accounts; +--------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+----------------+ | Sr | int(10) | NO | PRI | NULL | auto_increment | | Name | varchar(20) | YES | | NULL | | | amount | int(15) | YES | | NULL | | +--------+-------------+------+-----+---------+----------------+ 3 rows in set (0.10 sec)
它有一个带有 AUTO_INCREMENT 和 PRIMARY KEY 定义的文件 ‘Sr’。现在,如果我们尝试删除此 PRIMARY KEY,则 MySQL 将抛出错误,如下所示 −
mysql> Alter table Accounts DROP PRIMARY KEY; ERROR 1075 (42000): Incorrect table definition; there can be only one auto column and it must be defined as a key