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

MS SQL Server Discussion :

Job, fonctionnement sql bizarre! [2008]


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Consultant Décisionnel
    Inscrit en
    Janvier 2012
    Messages
    128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant Décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2012
    Messages : 128
    Par défaut Job, fonctionnement sql bizarre!
    Bonjour à tous et toutes,

    J'ai créé un Job sur SQL Server 2008 avec une petite condition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    if ((Select top 1 Extraction_Status  from SIGMA_SA.UserBODI.EMBI_LOAD_LOG Where Step = '011. Sales_Facts_ES') = 'Completed') 
     
    	EXEC stp_Test
     
    ELSE
    	UPDATE TEST.dbo.Test_Monitor
    	SET [Statut]= 'NO'
    	WHERE COUNTRY = 'ES'
    	RAISERROR ('The Testjob are not completed', 16, 1)
    Il m'exécute bien le EXEC stp_Test car la condition est vraie! Mais il m'exécute aussi le Else??? Je ne comprend vraiment pas pourquoi.

    Avez vous déjà rencontré ce cas? Ou avez vous une solution?

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    22 021
    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 : 22 021
    Billets dans le blog
    6
    Par défaut
    Non, mais il execute le RAISERROR !
    En effet deriière un ELSE une seule instruction est exécutée sauf si bloc BEGIN END.

    Donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    if ((Select top 1 Extraction_Status  from SIGMA_SA.UserBODI.EMBI_LOAD_LOG Where Step = '011. Sales_Facts_ES') = 'Completed') 
     
    	EXEC stp_Test
     
    ELSE
    BEGIN
    	UPDATE TEST.dbo.Test_Monitor
    	SET [Statut]= 'NO'
    	WHERE COUNTRY = 'ES'
    	RAISERROR ('The Testjob are not completed', 16, 1)
    END
    Il serait beaucoup plus intelligent de finalisez vos commandes SQL par le point-virgule qui, certes n'est pas obligatoire, mais aurais été essentiel pour repérer votre erreur. Donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    if  (Select top 1 Extraction_Status  
         from   SIGMA_SA.UserBODI.EMBI_LOAD_LOG 
         Where Step = '011. Sales_Facts_ES') = 'Completed'
     
    	EXEC stp_Test;
     
    ELSE
    BEGIN
    	UPDATE TEST.dbo.Test_Monitor
    	SET [Statut]= 'NO'
    	WHERE COUNTRY = 'ES';
    	RAISERROR ('The Testjob are not completed', 16, 1);
    END;
    Au passage toutes ces parenthèses sont inutile. De même il vaudrait mieux faire un EXISTS qu'un TOP 1 :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    IF EXISTS(Select *
           from   SIGMA_SA.UserBODI.EMBI_LOAD_LOG 
           Where  Step = '011. Sales_Facts_ES'
             AND  Extraction_Status   = 'Completed') 
       EXEC stp_Test;
    ELSE
    BEGIN
       UPDATE TEST.dbo.Test_Monitor
       SET [Statut]= 'NO'
       WHERE COUNTRY = 'ES';
       RAISERROR ('The Testjob are not completed', 16, 1);
    END;
    Bref, encore des progrès à faire !!!!

    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/ * * * * *

  3. #3
    Membre confirmé
    Homme Profil pro
    Consultant Décisionnel
    Inscrit en
    Janvier 2012
    Messages
    128
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Consultant Décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2012
    Messages : 128
    Par défaut
    Merci de la réponse rapide!

    Oui je sais tous les jours j'apprends de nouvelles choses mais il y a tellement à apprendre!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. requete sql bizarre
    Par noumian dans le forum Langage SQL
    Réponses: 3
    Dernier message: 24/06/2008, 10h42
  2. Syntaxe SQL bizarre pourquoi ?
    Par olaxius dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 30/01/2007, 18h36
  3. Gros problème d'export avec phpMyAdmin (.SQL bizarres)
    Par Meteorshadow dans le forum Outils
    Réponses: 3
    Dernier message: 27/08/2006, 05h44
  4. [SQL] Problème erreur sql bizarre
    Par baleiney dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 28/06/2006, 13h31
  5. Fenêtre d'execution des Jobs sur SQL
    Par fkgueye dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 20/12/2005, 16h50

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