Recherche des résultats totaux dans les requêtes MySQL pour la pagination avec décalage et limite
Dans les scénarios de pagination, déterminer le nombre total de résultats est crucial pour obtenir des résultats précis calculs de pages. L'utilisation du décalage et de la limite pour récupérer des données peut entraîner des problèmes d'efficacité de calcul lors de la tentative de calcul du nombre total à partir d'une requête distincte.
Pour résoudre ce problème, MySQL propose une solution avec SQL_CALC_FOUND_ROWS. En ajoutant cette directive à une requête, la base de données calcule le nombre total de lignes correspondantes sans réellement les récupérer :
SELECT SQL_CALC_FOUND_ROWS * FROM table WHERE category_id = 1 LIMIT 10 OFFSET 20;
Après avoir exécuté cette requête, la base de données calcule le nombre total de lignes en utilisant une autre requête interne comme :
SELECT FOUND_ROWS();
Cette technique fournit une méthode efficace et précise pour obtenir le nombre total de résultats.
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!