Comment afficher tous les index dans MySQL ou Schema

How Show All Indexes Mysql



L'index de base de données MySQL fait référence à un type de structure de données utilisé comme organisation des données dans une base de données et pour aider à augmenter la vitesse de diverses opérations effectuées dans MySQL.

Les index sont très utiles. Sans eux, MySQL doit analyser toute la table pour trouver les lignes et les colonnes pertinentes, ce qui peut être très inefficace dans les grandes bases de données.







Ce tutoriel se concentrera sur la façon d'afficher les informations d'index en utilisant la clause SHOW INDEXES dans MySQL.



Afficher les index de table

Pour afficher les informations d'index sur une table, nous utilisons la clause SHOW INDEXES suivie du nom de la table dont nous souhaitons obtenir les informations d'index.



La syntaxe générale est affichée comme suit :





AFFICHER LES INDEX tbl_name;

Par exemple, considérons l'une des tables de l'exemple de base de données Sakila. Nous pouvons obtenir les informations d'index comme indiqué dans la requête ci-dessous :

UTILISER du sakila ;

MONTRER LES INDEX DU film ;

La requête ci-dessus affichera les informations d'index de la table des films dans la base de données Sakila. La sortie est :



Comprendre les informations d'index

La commande SHOW INDEXES affiche les informations pertinentes sur les index dans la table spécifiée.

Voici les termes suivants et leurs informations respectives fournies :

  1. Table: Il s'agit de la première colonne de la sortie. Il affiche le nom de la table où réside l'index.
  2. Non-Unique: La deuxième colonne indique si l'index peut contenir un doublon. La valeur est un booléen, 1 indiquant que l'index peut contenir des doublons et 0 dans le cas contraire.
  3. Nom_clé : La troisième colonne affiche le nom de l'index. Par convention, la clé primaire prend le nom d'index PRIMARY.
  4. Seq_in_index : La quatrième colonne affiche le numéro de séquence de la colonne dans l'index à partir de la valeur 1.
  5. Nom de colonne: La cinquième colonne est simplement le nom de la colonne.
  6. Collation: La sixième colonne est une section qui montre comment la colonne est triée dans l'index. Il existe trois valeurs de tri, A étant l'ordre croissant, B indiquant l'ordre décroissant et NULL comme non trié.
  7. Cardinalité : La septième colonne montre l'unicité de la valeur des données. Dans les index, il affiche le nombre estimé de valeurs uniques dans l'index spécifique.
  8. Sous_partie : La huitième colonne affiche le préfixe d'index avec NULL, indiquant que la colonne entière est indexée.
  9. Emballé: La neuvième colonne montre comment les clés d'index sont compressées, NULL indiquant que les clés ne sont pas compressées.
  10. Nul: La dixième colonne spécifie si la colonne peut contenir des valeurs NULL. Oui, si la colonne peut contenir des valeurs nulles, et vide sinon.
  11. Index_type : La onzième colonne montre la méthode d'indexation telle que BTREE, HASH, RTREE et FULLTEXT.
  12. Commenter: La douzième colonne montre les informations sur un index non décrit dans sa colonne.
  13. Index_commentaire : La treizième colonne affiche des informations supplémentaires sur l'index spécifié à l'aide de l'attribut COMMENT lors de sa création.
  14. Visible: La quatorzième colonne est l'index visible par l'optimiseur de requête, avec les valeurs Oui et Non.
  15. Expression: La quinzième colonne s'affiche si l'index utilise une expression et non une valeur de colonne ou de préfixe de colonne.

INDICE: Les informations sur les index de la requête SHOW INDEXES sont similaires à celles de SQLStatistics.

Afficher les index de schéma

Vous pouvez également obtenir des informations d'index sur un schéma. La syntaxe générale pour obtenir ce résultat est la suivante :

SELECT table_name, index_name FROM INFORMATION_SCHEMA.STATISTICS WHERE TABLE_SCHEMA = schema_name;

Considérez la requête ci-dessous qui affiche des informations sur le schéma Sakila :

SELECT table_name, index_name FROM information_schema.statistics WHERE table_schema ='sakila';

Cela affichera des informations sur les index dans le schéma Sakila, comme indiqué dans la sortie ci-dessous :

+ --------------- + ----------------------------- +

|NOM DE LA TABLE|INDEX_NAME|

+ --------------- + ----------------------------- +

|acteur|PRIMAIRE|

|acteur|idx_actor_last_name|

|adresse|PRIMAIRE|

|adresse|idx_fk_city_id|

|adresse|idx_location|

|Catégorie|PRIMAIRE|

|ville|PRIMAIRE|

|ville|idx_fk_country_id|

|pays|PRIMAIRE|

|client|PRIMAIRE|

|client|idx_fk_store_id|

|client|idx_fk_address_id|

|client|idx_last_name|

|film|PRIMAIRE|

|film|idx_title|

|film|idx_fk_language_id|

|film|idx_fk_original_language_id|

|Acteur de cinéma|PRIMAIRE|

|Acteur de cinéma|PRIMAIRE|

|Acteur de cinéma|idx_fk_film_id|

|catégorie_film|PRIMAIRE|

|catégorie_film|PRIMAIRE|

|catégorie_film|fk_film_category_category|

|film_texte|PRIMAIRE|

|film_texte|idx_title_description|

|film_texte|idx_title_description|

|inventaire|PRIMAIRE|

|inventaire|idx_fk_film_id|

|inventaire|idx_store_id_film_id|

|inventaire|idx_store_id_film_id|

|-----------------------------SORTIE TRONQUÉE------------------- -------

Vous pouvez également obtenir des informations sur tous les schémas du serveur à l'aide de la requête ci-dessous :

SELECT table_name, index_name FROM information_schema.statistics;

REMARQUE : La requête ci-dessus vide beaucoup d'informations. Vous aurez rarement besoin d'obtenir des index de tous les schémas. Cependant, un exemple de sortie est ci-dessous :

+ -------------------- + ------------ +

|NOM DE LA TABLE|INDEX_NAME|

+ -------------------- + ------------ +

|innodb_table_stats|PRIMAIRE|

|innodb_table_stats|PRIMAIRE|

|innodb_index_stats|PRIMAIRE|

|innodb_index_stats|PRIMAIRE|

|innodb_index_stats|PRIMAIRE|

+ -------------------- + ------------ +

Conclusion

Dans ce didacticiel, nous avons expliqué comment utiliser la requête MySQL SHOW INDEXES pour obtenir des informations sur les index d'une table. Nous avons également envisagé d'utiliser information_schema pour obtenir des informations sur les index d'un ou de tous les schémas d'un serveur MySQL.