Maison  >  Article  >  base de données  >  Comment définir la clé primaire lors de la création d’une table dans MySQL ?

Comment définir la clé primaire lors de la création d’une table dans MySQL ?

青灯夜游
青灯夜游original
2020-10-09 09:19:5027155parcourir

Méthode de paramétrage : dans l'instruction "CREATE TABLE", spécifiez la clé primaire via le mot-clé "PRIMARY KEY", le format de syntaxe est "nom de champ type de données PRIMARY KEY [valeur par défaut]" ou "[contrainte CONSTRAINT nom] nom du champ PRIMARY KEY".

Comment définir la clé primaire lors de la création d’une table dans MySQL ?

Le nom complet de PRIMARY KEY est "contrainte de clé primaire", qui est la contrainte la plus fréquemment utilisée dans MySQL. Dans des circonstances normales, afin de permettre au SGBD de trouver plus rapidement les enregistrements dans la table, une clé primaire sera définie dans la table.

(Tutoriel recommandé : Tutoriel vidéo mysql )

Définir les contraintes de clé primaire lors de la création d'une table

Lors de la création d'une donnée table Pour définir des contraintes de clé primaire, vous pouvez définir une clé primaire pour un champ de la table ou une clé primaire commune pour plusieurs champs de la table. Mais quelle que soit la méthode utilisée, il ne peut y avoir qu’une seule clé primaire dans une table. Ce qui suit explique comment définir une clé primaire à champ unique et une clé primaire commune à champs multiples.

1) Définissez une clé primaire à champ unique

Dans l'instruction CREATE TABLE, spécifiez la clé primaire via le mot-clé PRIMARY KEY.

Spécifiez la clé primaire lors de la définition du champ. Le format de syntaxe est le suivant :

<字段名> <数据类型> PRIMARY KEY [默认值]

Exemple 1

Créez la table de données tb_emp3 dans la base de données test_db, dont la clé primaire est l'identifiant, l'instruction SQL et les résultats en cours d'exécution sont les suivants.

mysql> CREATE TABLE tb_emp3
    -> (
    -> id INT(11) PRIMARY KEY,
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT
    -> );
Query OK, 0 rows affected (0.37 sec)
mysql> DESC tb_emp3;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id     | int(11)     | NO   | PRI | NULL    |       |
| name   | varchar(25) | YES  |     | NULL    |       |
| deptId | int(11)     | YES  |     | NULL    |       |
| salary | float       | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
4 rows in set (0.14 sec)

Ou spécifiez la clé primaire après avoir défini tous les champs. Le format de syntaxe est le suivant :

[CONSTRAINT <约束名>] PRIMARY KEY [字段名]

Exemple 2

Créez la table de données tb_emp4 dans la base de données test_db, dont la clé primaire est id , les instructions SQL et les résultats d'exécution sont les suivants.

mysql> CREATE TABLE tb_emp4
    -> (
    -> id INT(11),
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT,
    -> PRIMARY KEY(id)
    -> );
Query OK, 0 rows affected (0.37 sec)
mysql> DESC tb_emp4;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id     | int(11)     | NO   | PRI | NULL    |       |
| name   | varchar(25) | YES  |     | NULL    |       |
| deptId | int(11)     | YES  |     | NULL    |       |
| salary | float       | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
4 rows in set (0.14 sec)

2) Définir la clé primaire commune lors de la création de la table

La clé primaire dite commune signifie que la clé primaire est composée de plusieurs champs dans une table .

Par exemple, lors de la configuration d'un tableau de données de sélection de cours d'étudiant, devez-vous utiliser le numéro d'étudiant comme clé primaire ou le numéro de cours comme clé primaire ? Si le numéro d’étudiant est utilisé comme clé primaire, alors un étudiant ne peut choisir qu’un seul cours. Si le numéro de cours est utilisé comme clé primaire, alors un seul étudiant peut choisir un cours. De toute évidence, ces deux situations sont irréalistes.

En fait, lors de la conception d'un calendrier de sélection de cours pour étudiants, la limitation est qu'un étudiant ne peut choisir qu'une seule fois le même cours. Par conséquent, le numéro d’étudiant et le numéro de cours peuvent être regroupés en tant que clé primaire, qui est une clé primaire commune.

La clé primaire est composée de plusieurs champs. Le format de syntaxe est le suivant :

PRIMARY KEY [字段1,字段2,…,字段n]

Remarque : Lorsque la clé primaire est composée de plusieurs champs, la contrainte de clé primaire ne peut pas être déclarée directement après le nom du champ.

Exemple 3

Créez la table de données tb_emp5. Supposons qu'il n'y ait pas d'identifiant de clé primaire dans la table Afin d'identifier de manière unique un employé, vous pouvez combiner le nom et le deptId comme clé primaire. . L'instruction SQL et les résultats d'exécution sont les suivants.

mysql> CREATE TABLE tb_emp5
    -> (
    -> name VARCHAR(25),
    -> deptId INT(11),
    -> salary FLOAT,
    -> PRIMARY KEY(id,deptId)
    -> );
Query OK, 0 rows affected (0.37 sec)
mysql> DESC tb_emp5;
+--------+-------------+------+-----+---------+-------+
| Field  | Type        | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| name   | varchar(25) | NO   | PRI | NULL    |       |
| deptId | int(11)     | NO   | PRI | NULL    |       |
| salary | float       | YES  |     | NULL    |       |
+--------+-------------+------+-----+---------+-------+
3 rows in set (0.14 sec)

Recommandations associées : formation php

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn