Maison >base de données >tutoriel mysql >Pourquoi ma table MySQL apparaît-elle dans SHOW TABLES mais pas dans les requêtes SELECT ?

Pourquoi ma table MySQL apparaît-elle dans SHOW TABLES mais pas dans les requêtes SELECT ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-12-07 05:49:12731parcourir

Why Does My MySQL Table Appear in SHOW TABLES But Not in SELECT Queries?

L'énigme de la disparition des tables MySQL résolue

En cas d'incohérence où SHOW TABLES affiche une table inaccessible pour les opérations de données, telles que SELECT, la cause sous-jacente reste souvent insaisissable. Un coupable potentiel est un fichier de table corrompu, qui peut ne pas être détecté par SHOW TABLES.

Dans un cas particulier, un utilisateur a rencontré ce problème après avoir modifié le répertoire de données MySQL. Bien que les fichiers de la table soient présents, la sélection des données à partir de celle-ci a entraîné l'erreur :

ERROR 1146 (42S02): Table 'database.TABLE_ONE' doesn't exist

Ce comportement paradoxal a conduit à la spéculation selon laquelle SHOW TABLES vérifie uniquement l'existence des fichiers, pas leur intégrité. Cependant, la racine du problème a finalement été découverte :

  • La base de données en question utilisait des tables InnoDB, qui s'appuient sur les fichiers ibdata1 et ib_logfile stockés dans le répertoire de données MySQL.
  • Ces les fichiers n'étaient pas présents dans le nouveau répertoire de données lorsque la base de données a été déplacée.

Pour résoudre le problème, l'utilisateur a copié ces fichiers dans le nouveau répertoire de données. répertoire, qui a restauré avec succès l’accessibilité des tables. Cela souligne l'importance d'inclure ces fichiers lors de la copie de bases de données basées sur InnoDB pour garantir leur fonctionnalité.

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