Exporter (0) Imprimer
Développer tout
Développer Réduire
Cet article a fait l'objet d'une traduction manuelle. Déplacez votre pointeur sur les phrases de l'article pour voir la version originale de ce texte. Informations supplémentaires.
Traduction
Source

sp_updatestats (Transact-SQL)

Exécute la procédure UPDATE STATISTICS sur toutes les tables définies par l'utilisateur et les tables internes de la base de données active.

Pour plus d'informations sur UPDATE STATISTICS, consultez UPDATE STATISTICS (Transact-SQL). Pour plus d'informations sur les statistiques, consultez Statistiques.

S'applique à : SQL Server (SQL Server 2008 jusqu'à la version actuelle, Base de données SQL Windows Azure (version initiale jusqu'à la version actuelle).

Icône Lien de rubrique Conventions de la syntaxe Transact-SQL

sp_updatestats [ [ @resample = ] 'resample']

0 (réussite) ou 1 (échec)

[ @resample =] 'resample'

Spécifie que sp_updatestats utilisera l'option RESAMPLE de l'instruction UPDATE STATISTICS. Si l'argument 'resample' n'est pas spécifié, la procédure sp_updatestats met à jour les statistiques en utilisant l'échantillonnage par défaut. resample est de type varchar(8) avec NO comme valeur par défaut.

La procédure sp_updatestats exécute UPDATE STATISTICS, en spécifiant le mot clé ALL sur toutes les tables définies par l'utilisateur et les tables internes de la base de données. sp_updatestats affiche des messages indiquant sa progression. Une fois la mise à jour terminée, cette procédure signale que les statistiques ont été mises à jour pour toutes les tables.

sp_updatestats met à jour les statistiques sur les index non cluster désactivés, mais ne met pas à jour les statistiques sur les index cluster désactivés.

Pour les tables sur disque, sp_updatestats met à jour uniquement les statistiques qui nécessitent une mise à jour en fonction des informations de rowmodctr dans l'affichage catalogue sys.sysindexes ; cela permet d'éviter les mises à jour non nécessaires des statistiques pour les lignes qui n'ont pas été modifiées. Les statistiques sur les tables optimisées en mémoire sont toujours mises à jour lors de l'exécution de sp_updatestats. Par conséquent, n'exécutez pas sp_updatestats plus que nécessaire.

sp_updatestats peut déclencher une recompilation des procédures stockées ou d'autres codes compilés. Cependant, sp_updatestats peut ne pas provoquer de recompilation si un seul plan de requête est possible pour les tables référencées et les index définis sur elles. Une recompilation serait inutile dans ce cas, même si les statistiques sont mises à jour.

Avec les bases de données dont le niveau de compatibilité est inférieur à 90, l'exécution de sp_updatestats ne conserve pas le dernier paramètre NORECOMPUTE pour des statistiques spécifiques. Avec les bases de données dont le niveau de compatibilité est supérieur ou égal à 90, l'exécution de sp_updatestats conserve la dernière option NORECOMPUTE pour des statistiques spécifiques. Pour plus d'informations sur la désactivation et la réactivation des mises à jour des statistiques, consultez Statistiques.

Nécessite l'appartenance au rôle serveur fixe sysadmin ou la propriété de la base de données (dbo).

Cet exemple met à jour les statistiques des tables de la base de données AdventureWorks2012 .

USE AdventureWorks2012;
GO
EXEC sp_updatestats; 

Ajouts de la communauté

AJOUTER
Afficher:
© 2014 Microsoft