Describeemployee;+------------+-------------+------+-- -- -+---------+-------+|Champ |Type  "/> Describeemployee;+------------+-------------+------+-- -- -+---------+-------+|Champ |Type  ">

Maison  >  Article  >  base de données  >  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
WBOYavant
2023-09-01 12:33:03927parcourir

如果我多次在同一列上添加 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)

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)

À 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

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)

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

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)

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer