Rumah  >  Artikel  >  pangkalan data  >  mysql设置主键的两种方式

mysql设置主键的两种方式

醉折花枝作酒筹
醉折花枝作酒筹asal
2021-04-01 16:39:4328381semak imbas

本篇文章介绍一下mysql如何设置主键。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。mysql设置主键的两种方式

主键叫做主键约束,是数据库里经常用的一种约束。为了方便查找数据,会在每个表里都添加上一个主键。

主键的约束条件:

  • 主键的值不能为空

  • 主键应该是明确且单一的

  • 为了查询和处理的效率,主键一般设置在整数上

  • 由于需要查询数据,所以主键不能相同,所以我们会配合auto_increment(自增)属性进行使用

  • 一个数据表中只有一个主键,不能有多个主键

在创建表的时候设置主键

create table 表名(字段名称 类型 primary key(字段名称));

其中:

  • 表名:是操作的数据表的名字;

  • 字段名称:是我们需要创建的字段;

  • 类型:需要操作的数据表字段类型;

mysql> create table cmcc (id int,name varchar(25),primary key (id));
Query OK, 0 rows affected

mysql> desc cmcc;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | NO   | PRI | NULL    |       |
| name  | varchar(25) | YES  |     | NULL    |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set

这样就将主键设置好了。

在修改表的时候设置主键

alter table 表名 add primary key(字段);

如果在创建数据表的时候忘记设主键,可以在修改表的时候设置。(ps:我在修改表设置主键之前已经将创建时设置的主键删掉了,不存在一张数据表存在多个主键的问题)

mysql> alter table cmcc add primary key(name);
Query OK, 0 rows affected
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc cmcc;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | NO   |     | NULL    |       |
| name  | varchar(25) | NO   | PRI | NULL    |       |
+-------+-------------+------+-----+---------+-------+
2 rows in set

相关免费学习推荐:mysql视频教程

Atas ialah kandungan terperinci mysql设置主键的两种方式. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn