Lorsque vous travaillez avec des bases de données contenant des coordonnées géographiques dans différentes colonnes, interroger efficacement des données en fonction d'une liste de coordonnées peut être crucial. Dans ce cas, nous avons un tableau à quatre colonnes : x0, y0, x1 et y1, chacune représentant une position géographique spécifique. La table est indexée en fonction de ces quatre colonnes dans la séquence x0, y0, x1, y1.
Pour interroger ces données, l'utilisation de la clause IN avec plusieurs colonnes peut être bénéfique. Cependant, MySQL présente certaines limites lorsqu'il s'agit d'utiliser directement la syntaxe (a, b) IN ((...), (...)).
Réécriture du prédicat IN pour une efficacité maximale :
Pour surmonter ces limitations et profiter de l'index existant, nous pouvons réécrire le prédicat IN sous la forme d'une série de conditions OR. Chaque condition vérifie si les valeurs des quatre colonnes correspondent à l'une des paires de coordonnées spécifiées :
( (x0 = 4 AND y0 = 3 AND x1 = 5 AND y1 = 6) OR (x0 = 9 AND y0 = 3 AND x1 = 2 AND y1 = 1) )
En utilisant cette approche, MySQL peut utiliser efficacement l'index sur les colonnes et exécuter la requête efficacement.
Optimisations dans les versions plus récentes de MySQL :
Notez que les versions plus récentes de MySQL ont résolu les problèmes de performances associés à l'utilisation de Clause IN avec plusieurs colonnes. L'optimiseur de ces versions a été amélioré pour générer des plans d'exécution plus efficaces.
En particulier, la syntaxe (a, b) IN ((...), (...)) est désormais prise en charge dans MySQL , et l'optimiseur peut générer des plans qui exploitent les index disponibles. Cela élimine le besoin de réécriture manuelle du prédicat IN comme décrit ci-dessus.
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!