首页  >  文章  >  数据库  >  如果我尝试从AUTO_INCREMENT列中删除PRIMARY KEY约束会发生什么?

如果我尝试从AUTO_INCREMENT列中删除PRIMARY KEY约束会发生什么?

王林
王林转载
2023-08-23 21:21:021309浏览

如果我尝试从AUTO_INCREMENT列中删除PRIMARY KEY约束会发生什么?

正如我们所知,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

以上是如果我尝试从AUTO_INCREMENT列中删除PRIMARY KEY约束会发生什么?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:tutorialspoint.com。如有侵权,请联系admin@php.cn删除