Indexation des valeurs de date pour améliorer les performances de recherche
Le problème en question concerne l'optimisation des recherches de table en fonction du composant de date d'un champ DATETIME dans MySQL. La table donnée, "transactionlist", contient plus d'un million d'enregistrements et interroge spécifiquement une seule date, telle que "2008-08-17", à l'aide de la requête "SELECT * FROM transactionlist où date(TranDateTime) = '2008-08 -17'", entraîne un retard important.
Pour résoudre ce goulot d'étranglement en termes de performances, envisagez de créer un index sur la partie date de "TranDateTime". L'indexation est une technique de base de données qui organise les données de manière structurée, ce qui facilite et accélère la localisation d'informations spécifiques dans une table. En indexant la partie date de « TranDateTime », MySQL peut éviter d'avoir à effectuer une analyse complète de la table, ce qui améliore considérablement les performances des requêtes.
Pour créer un index sur la partie date de « TranDateTime », exécutez la commande commande suivante :
CREATE INDEX idx_date ON transactionlist (DATE(TranDateTime));
Une fois cet index créé, la requête utilisée pour récupérer toutes les transactions à une date spécifique peut être réécrite comme :
SELECT * FROM transactionlist WHERE DATE(TranDateTime) = '2008-08-17';
En utilisant l'index sur "DATE (TranDateTime)", MySQL peut accéder directement aux lignes pertinentes sans analyser la table entière, ce qui entraîne une réduction substantielle du temps de requête.
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!