Maison > base de données > tutoriel mysql > Que se passe-t-il si j'ajoute plusieurs fois une contrainte UNIQUE sur la même colonne ?

Que se passe-t-il si j'ajoute plusieurs fois une contrainte UNIQUE sur la même colonne ?

WBOY
Libérer: 2023-09-01 12:33:03
avant
1016 Les gens l'ont consulté

如果我多次在同一列上添加 UNIQUE 约束,会发生什么情况?

Lorsque nous ajoutons plusieurs fois une contrainte UNIQUE sur la même colonne, MySQL créera un index sur cette colonne pour le nombre de fois où nous ajoutons la contrainte UNIQUE.

Exemple

Supposons que nous ayons la table "employé" avec une contrainte UNIQUE sur la colonne "empid". Cela peut être vérifié par la requête suivante -

mysql> Describe employee;
+------------+-------------+------+-----+---------+-------+
| Field      | Type        | Null | Key | Default | Extra |
+------------+-------------+------+-----+---------+-------+
| empid      | int(11)     | YES  | UNI | NULL    |       |
| first_name | varchar(20) | YES  |     | NULL    |       |
| last_name  | varchar(20) | YES  |     | NULL    |       |
+------------+-------------+------+-----+---------+-------+
3 rows in set (0.12 sec)
Copier après la connexion

Maintenant, lorsque nous exécutons la requête SHOW INDEX, elle donne le nom de l'index et il n'y a qu'un seul index, créé sur la colonne "empid".

mysql> Show index from employee\G;
*************************** 1. row ***************************
        Table: employee
   Non_unique: 0
     Key_name: empid
 Seq_in_index: 1
  Column_name: empid
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null: YES
   Index_type: BTREE
      Comment:
Index_comment:
1 row in set (0.00 sec)
Copier après la connexion

À l'aide de la requête suivante, nous avons ajouté une autre contrainte UNIQUE sur la même colonne "empid" -

mysql> Alter table employee ADD UNIQUE(empid);
Query OK, 0 rows affected (0.21 sec)
Records: 0 Duplicates: 0 Warnings: 0
Copier après la connexion
Copier après la connexion

Maintenant, lorsque nous exécuterons la requête SHOW INDEX, elle donnera le nom de l'index, c'est-à-dire sur "empid" Deux index "empid" et "empid_2" sont créés sur la colonne.

mysql> Show index from employee12\G;
*************************** 1. row ***************************
        Table: employee
   Non_unique: 0
     Key_name: empid
 Seq_in_index: 1
  Column_name: empid
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null: YES
   Index_type: BTREE
      Comment:
Index_comment:
*************************** 2. row ***************************
        Table: employee
   Non_unique: 0
     Key_name: empid_2
 Seq_in_index: 1
  Column_name: empid
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null: YES
   Index_type: BTREE
      Comment:
Index_comment:
2 rows in set (0.00 sec)
Copier après la connexion

A l'aide de la requête suivante, nous avons ajouté une autre contrainte UNIQUE sur la même colonne "empid" -

mysql> Alter table employee ADD UNIQUE(empid);
Query OK, 0 rows affected (0.21 sec)
Records: 0 Duplicates: 0 Warnings: 0
Copier après la connexion
Copier après la connexion

Maintenant, lorsque nous lancerons la requête SHOW INDEX, elle donnera le nom de l'index, sur la colonne " empid" Les trois index "empid", "empid_2" et "empid_3" créés sur ".

mysql> Alter table employee ADD UNIQUE(empid);
Query OK, 0 rows affected (0.30 sec)
Records: 0 Duplicates: 0 Warnings: 0

mysql> Show index from employee\G;
*************************** 1. row ***************************
        Table: employee
   Non_unique: 0
     Key_name: empid
 Seq_in_index: 1
  Column_name: empid
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null: YES
   Index_type: BTREE
      Comment:
Index_comment:
*************************** 2. row ***************************
        Table: employee
   Non_unique: 0
     Key_name: empid_2
 Seq_in_index: 1
  Column_name: empid
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null: YES
   Index_type: BTREE
      Comment:
Index_comment:
*************************** 3. row ***************************
        Table: employee
   Non_unique: 0
     Key_name: empid_3
 Seq_in_index: 1
  Column_name: empid
    Collation: A
  Cardinality: 0
     Sub_part: NULL
       Packed: NULL
         Null: YES
   Index_type: BTREE
      Comment:
Index_comment:
3 rows in set (0.00 sec)
Copier après la connexion

En ce sens, on peut dire que MySQL créera un index unique sur la colonne le nombre de fois que nous ajouterons la contrainte UNIQUE sur cette colonne.

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!

source:tutorialspoint.com
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal