Maison > base de données > tutoriel mysql > Comment puis-je optimiser les requêtes COUNT lentes dans SQL Server ?

Comment puis-je optimiser les requêtes COUNT lentes dans SQL Server ?

Patricia Arquette
Libérer: 2024-12-29 04:32:11
original
885 Les gens l'ont consulté

How Can I Optimize Slow COUNT Queries in SQL Server?

Optimisation des performances SQL : compter les requêtes

Lorsque vous travaillez avec de grands ensembles de données, les requêtes qui comptent des lignes peuvent devenir coûteuses en termes de calcul et ralentir les performances. Cet article explore les implications en termes de performances des requêtes de nombre et propose des solutions pour les optimiser dans SQL Server.

Différences de performances dans les requêtes de nombre

Considérez la requête SQL suivante sur une table avec plus de 20 millions de lignes :

if (select count(*) from BookChapters) = 0
Copier après la connexion

Cette requête s'exécute rapidement, car SQL Server l'optimise into :

if exists(select * from BookChapters)
Copier après la connexion

Essentiellement, il vérifie la présence de lignes plutôt que de les compter. Cependant, si la requête est modifiée en :

if (select count(*) from BookChapters) = 1
Copier après la connexion

ou

if (select count(*) from BookChapters) > 1
Copier après la connexion

le temps d'exécution augmente considérablement jusqu'à plus de 10 minutes.

Comprendre l'écart de performances

La différence de performances vient du fait que pour les requêtes de comptage avec des conditions (par exemple, = 1, > 1), SQL Server utilise une approche différente. Il utilise l'index non clusterisé le plus étroit pour compter les lignes. Étant donné que la table de l'exemple ne dispose d'aucun index non clusterisé, SQL Server doit recourir à une analyse complète de la table, ce qui entraîne un ralentissement des performances.

Techniques d'optimisation

Pour optimiser comptez les requêtes, envisagez les techniques suivantes :

  • Utilisez EXISTS (INSTEAD OF COUNT = 0) : Pour les requêtes où vous devez uniquement déterminer si la table est vide, utilisez EXISTS au lieu de COUNT = 0.
  • Créer un index non cluster : Créez un index non-cluster index clusterisé sur une colonne utilisé dans la clause WHERE pour améliorer les recherches de lignes et réduire le besoin d'une table complète analyses.
  • Utiliser la table système SysIndexes : Utilisez la requête suivante pour obtenir un nombre rapide de lignes :
SELECT OBJECT_NAME(i.id) [Table_Name], i.rowcnt [Row_Count]
FROM sys.sysindexes i WITH (NOLOCK)
WHERE i.indid in (0,1)
ORDER BY i.rowcnt desc
Copier après la connexion
  • SOMME des lignes dans les partitions (SQL 2005) : Utilisez la requête suivante pour obtenir une ligne approximative count :
select sum (spart.rows)
from sys.partitions spart
where spart.object_id = object_id(’YourTable’)
and spart.index_id < 2
Copier après la connexion
  • Max de lignes dans SysIndex (SQL 2000) : Pour les anciennes versions de SQL, utilisez :
select max(ROWS)
from sysindexes
where id = object_id(’YourTable’)
Copier après la connexion

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 de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal