IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Développement SQL Server Discussion :

Aide sur rapidité requete


Sujet :

Développement SQL Server

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Décembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2015
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Aide sur rapidité requete
    Bonjour,

    Je souhaite vous faire part d'une différence de rapidité de requete alors qu'elle me semble identique :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    USE [MA_BASE]
    GO
    DECLARE @_IdProjet INT
    DECLARE @_IdLot INT
    Set @_IdProjet = 1070310
    Set @_IdLot = 0
    SELECT *
    FROM [dbo].[udf_Tbl_Get_Inf_ArticleConfigureAX] (@_IdProjet,@_IdLot)
    GO
    Cette requete met plus d'une minute à me renvoyer un résultat.
    Si je modifie FROM [dbo].[udf_Tbl_Get_Inf_ArticleConfigureAX] (@_IdProjet,@_IdLot) par FROM [dbo].[udf_Tbl_Get_Inf_ArticleConfigureAX] (@_IdProjet,0), la réponse est quasi instantanée.

    Une idée sur cette différence de temps?
    Merci de votre retour

  2. #2
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    bonjour

    Qu'est-ce que ça donne comme ceci avec OPTION (RECOMPILE) ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT *
    FROM [dbo].[udf_Tbl_Get_Inf_ArticleConfigureAX] (@_IdProjet,@_IdLot)
    OPTION (RECOMPILE)
    Il est probable que dans le cas avec la variable, SQL Server génère un plan d’exécution optimisé pour n'importe quelle valeur, alors que dans le deuxième cas, le plan soit optimisé spécifiquement pour la valeur 0.

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Décembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2015
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Bonjour,

    tout d'abord merci pour votre réponse.
    En effet avec l'option recompile cela renvoie une réponse quasi instantanément.
    DOnc, maintenant comment faire pour rendre optimale la requete?
    Merci d'avance,

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    laisser le RECOMPILE pourrait être une solution, si la requete n'est pas appelée trop souvent.
    Il y a d'autres pistes, mais il faudrait mieux connaitre le contexte.

    Que représente ce paramètre IDLot ? combien de valeurs distinctes peut-il prendre ? est-ce que 0 est une valeur particulière ? est-ce qu'elle filtre plus que d'autres valeurs ?

    Est-ce que la requête est souvent appelée avec ce paramètre = 0 ? (auquel cas, une alternative serait la clause OPTIMIZE FOR...

    Pouvez vous poster la code de la fonction table ? ça serait déjà un début pour mieux vous aider

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 763
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 763
    Points : 52 554
    Points
    52 554
    Billets dans le blog
    5
    Par défaut
    Citation Envoyé par dimitry44 Voir le message
    Bonjour,

    Je souhaite vous faire part d'une différence de rapidité de requete alors qu'elle me semble identique : Une idée sur cette différence de temps?
    Merci de votre retour
    En règle générale les fonctions de type UDF ne sont pas optimisable, car c'est de l'itératif. Seules les opérations ensmblistes (donc des requêtes dépourvues de fonctions) sont optimisables, car on peut obtenir des stats dessus, ce qui n'est pas le cas des fonctions, pour lesquelles il faut itérer, donc effectuer les calculs pour avoir une didée du coût, et donc c'est trop tard.

    Supprimez votre fonction, et réalisez la requêtes puerement en ensembliste et vos problèmes vont disparaître !

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

Discussions similaires

  1. [Debutant] Aide sur une requete normée
    Par Wisefool dans le forum Oracle
    Réponses: 2
    Dernier message: 14/04/2006, 18h41
  2. Besoin d'aide sur une requete ds un trigger
    Par ideal dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 15/02/2006, 10h05
  3. [MySQL] aide sur une requete
    Par dj-julio dans le forum Langage SQL
    Réponses: 5
    Dernier message: 12/01/2006, 14h25
  4. petite aide sur une requete INSERT INTO
    Par bonneti dans le forum Langage SQL
    Réponses: 3
    Dernier message: 14/03/2005, 15h17
  5. Aide sur une requete de sélection
    Par stephdiplo150 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 16/01/2004, 10h40

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo