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.
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!