vendredi 27 février 2009

Parameters sniffing SQL Server

Ceci est un retour d’expérience lorsque j’ai travaillé sur un projet utilisant SQL Server 2000.

Lorsqu’une procédure stockée est créé, le plan d’éxécution n’est pas encore généré mais ce dernier est crée lors du premier appel à la procédure après sa compilation

Ce plan d’éxécution est ensuite stocké en cache et sera réutilisé.

Si la procédure possède des paramètres, lors du premier appel, les paramètres donnés seront pris en compte pour la compilation et la création du plan d’éxécution. Le plan sera donc optimisé par rapport à ces paramètres. C’est ce qu’on appelle « parameters sniffing ». Ce plan ne sera probablement pas optimisé pour d’autre valeur de paramètre.

Dans la plupart des requêtes, ce mécanisme ne pose pas de problème.

Mais lorsque la requête est complexe et que les valeurs ne sont pas bien distribuées sur la colonne filtrée, le « parameters sniffing » ralentit considérablement la procedure stocké du fait de la mauvaise estimation.

Lorsqu’une procédure stockée s’éxécute beacuoup plus lentement qu’une requête à la volée, les deux solutions ci-dessous peuvent être considérées :

1. Recompiler la procédure avant chaque exécution avec le mot clé « with recompile »
Exemple :
create Proc procTest (@pTest int)
with recompile
as
select colTest from tbTest where colTest = @pTest;



2. Utiliser les variables locales
Exemple:
create Proc procTest (@pTest int)
as
declare @varTest int
set @varTest = @pTest
select colTest from tbTest where colTest = @varTest;

Aucun commentaire:

Enregistrer un commentaire