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 :

[SQL SERVER 2005] Pb de syntaxe


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de valoji
    Inscrit en
    Septembre 2005
    Messages
    124
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Septembre 2005
    Messages : 124
    Par défaut [SQL SERVER 2005] Pb de syntaxe
    Bonjour,

    je suis en train de migrer une requête qui fonctionnait sous informix en sqlserver 2005.
    Voici ma requête d'origine :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    select ufocod, ufolib, sum(decode((select count(*) from parli rli where rli.rlinumser = parli.rlinumser 
    and rlidatdebval <= date(:par1)),0,decode((select count(*) from parli rli where rli.rlinumser = parli.rlinumser),
    0,( - ufodatdebval + ufodatdebval + date(:par2) - date(:par1) + 1) ,
    rlidatdebval - date(:par1)),0) + decode((select count(*) from parli rli where rli.rlinumser = parli.rlinumser 
    and (rlidatfinval is null or rlidatfinval >= date(:par2))),0,decode((select count(*) 
    from parli rli where rli.rlinumser = parli.rlinumser),0,0,date(:par2) - rlidatfinval + 1),0)) as NbJourInocc, 
    SUM(date(:par2) - date(:par1) + 1) as NbJourTot from stlit, stufo, outer(parli) 
    where stlit.ufonumser = stufo.ufonumser and parli.litnumser = stlit.litnumser 
    and rlidatdebval <= date(:par2) and (rlidatfinval is null or rlidatfinval >= date(:par1)) 
    and ufocod between :par3 and :par4 and litdis = 'O' GROUP BY 1,2 order by ufocod
    Voici ma requête modifiée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    select ufocod, ufolib, 
    sum(
    	 case (select count(*) from parli rli where rli.rlinumser = parli.rlinumser and rlidatdebval <= '01/01/2008')
    	 when 0 then case(select count(*) from parli rli where rli.rlinumser = parli.rlinumser) 
    				  when 0 then (- ufodatdebval + ufodatdebval + '31/12/2008' - '01/01/2008' + 1) 
         when (rlidatdebval - '01/01/2008') then 0
     
      + 
         case (select count(*) from parli rli where rli.rlinumser = parli.rlinumser and (rlidatfinval is null or rlidatfinval >= '31/12/2008'))
    	 when 0 then case (select count(*) from parli rli where rli.rlinumser = parli.rlinumser) 
    				  when 0 then 0
    	 when ('31/12/2008' - rlidatfinval + 1) then 0
       ) NbJourInocc  , 
     
    SUM('31/12/2008' - '01/01/2008' + 1)  NbJourTot 
     
    from stufo join stlit 
    				LEFT OUTER JOIN parli on stlit.litnumser = parlit.litnumser and rlidatdebval <= '31/12/2008' 
    											and (rlidatfinval is null or rlidatfinval >= '01/01/2008') 
    			on stufo.ufonumser = stlit.ufonumser 
    where  ufocod between 0 
    and 99999 and litdis = 'O' 
    GROUP BY 1,2 
    order by ufocod
    J'ai une erreur de syntaxe :
    Msg*102, Niveau*15, État*1, Ligne*4
    Syntaxe incorrecte vers ')'.
    Merci pour votre aide.
    Valoji
    SQL SERVER 2005 express

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    956
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 956
    Par défaut
    Bonjour,
    Une piste il manque les End des select
    Citation Envoyé par msdn
    CASE input_expression
    WHEN when_expression THEN result_expression
    [ ...n ]
    [
    ELSE else_result_expression
    ]
    END
    A+
    Soazig

  3. #3
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    956
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 956
    Par défaut
    Rebonjour,
    Voilà ce que cela donnerait.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    SELECT   ufocod,
             ufolib,
             SUM(
                      CASE
                           (SELECT COUNT(*)
                           FROM    parli rli
                           WHERE   rli.rlinumser = parli.rlinumser
                               AND rlidatdebval <= '01/01/2008'
                           )
                               WHEN 0
                               THEN
                                        CASE
                                             (SELECT COUNT(*)
                                             FROM    parli rli
                                             WHERE   rli.rlinumser = parli.rlinumser
                                             )
                                                 WHEN 0
                                                 THEN (- ufodatdebval + ufodatdebval + '31/12/2008' - '01/01/2008' + 1)
                                        END
                               WHEN (
                                                 rlidatdebval - '01/01/2008'
                                        )
                               THEN 0
                      END +
                      CASE
                           (SELECT COUNT(*)
                           FROM    parli rli
                           WHERE   rli.rlinumser = parli.rlinumser
                               AND (
                                           rlidatfinval IS NULL
                                        OR rlidatfinval >= '31/12/2008'
                                   )
                           )
                               WHEN 0
                               THEN
                                        CASE
                                             (SELECT COUNT(*)
                                             FROM    parli rli
                                             WHERE   rli.rlinumser = parli.rlinumser
                                             )
                                                 WHEN 0
                                                 THEN 0
                                                 WHEN (
                                                                   '31/12/2008' - rlidatfinval + 1
                                                          )
                                                 THEN 0
                                        END )     NbJourInocc ,
             SUM('31/12/2008' - '01/01/2008' + 1) NbJourTot
    FROM     stufo
             JOIN stlit
             LEFT OUTER JOIN parli
             ON       stlit.litnumser = parlit.litnumser
                  AND rlidatdebval   <= '31/12/2008'
                  AND (
                               rlidatfinval IS NULL
                            OR rlidatfinval >= '01/01/2008'
                      )
             ON       stufo.ufonumser = stlit.ufonumser
    WHERE    ufocod BETWEEN 0 AND 99999
         AND litdis = 'O'
    GROUP BY 1,2
    ORDER BY ufocod
    mais je ne suis pas sure de mettre les end au bon endroit.
    PS: As tu remarqué que - ufodatdebval + ufodatdebval + '31/12/2008' - '01/01/2008' + 1
    cela peut s'écrire '31/12/2008' - '01/01/2008' + 1
    -x+x cela fait0 chez moi.
    Dans la requête informix c'était déjà comme cela.
    PS2. J'ai d'abord modifié ta requete puis j'ai utilisé http://sqlinform.com/ pour l'indenter
    A+
    Soazig

  4. #4
    Membre confirmé Avatar de valoji
    Inscrit en
    Septembre 2005
    Messages
    124
    Détails du profil
    Informations personnelles :
    Âge : 47

    Informations forums :
    Inscription : Septembre 2005
    Messages : 124
    Par défaut
    Bonjour,

    merçi pour l'adresse du site web, je ne connaissais pas. Par ailleurs, j'ai réutilisé la requête, mais j'ai de nouveaux des messages d'erreur :

    Voici la requête (Il manquait un end) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    SELECT   ufocod,
             ufolib,
             SUM(
                      CASE
                           (SELECT COUNT(*)
                           FROM    parli rli
                           WHERE   rli.rlinumser = parli.rlinumser
                               AND rlidatdebval <= '01/01/2008'
                           )
                               WHEN 0
                               THEN
                                        CASE
                                             (SELECT COUNT(*)
                                             FROM    parli rli
                                             WHERE   rli.rlinumser = parli.rlinumser
                                             )
                                                 WHEN 0
                                                 THEN (- ufodatdebval + ufodatdebval + '31/12/2008' - '01/01/2008' + 1)
                                        END
                               WHEN (
                                                 rlidatdebval - '01/01/2008'
                                        )
                               THEN 0
                      END +
                      CASE
                           (SELECT COUNT(*)
                           FROM    parli rli
                           WHERE   rli.rlinumser = parli.rlinumser
                               AND (
                                           rlidatfinval IS NULL
                                        OR rlidatfinval >= '31/12/2008'
                                   )
                           )
                               WHEN 0
                               THEN
                                        CASE
                                             (SELECT COUNT(*)
                                             FROM    parli rli
                                             WHERE   rli.rlinumser = parli.rlinumser
                                             )
                                                 WHEN 0
                                                 THEN 0
                                                 WHEN (
                                                                   '31/12/2008' - rlidatfinval + 1
                                                          )
                                                 THEN 0
                                        END 
    					END)     NbJourInocc ,
             SUM('31/12/2008' - '01/01/2008' + 1) NbJourTot
    FROM     stufo
             JOIN stlit
             LEFT OUTER JOIN parli
             ON       stlit.litnumser = parlit.litnumser
                  AND rlidatdebval   <= '31/12/2008'
                  AND (
                               rlidatfinval IS NULL
                            OR rlidatfinval >= '01/01/2008'
                      )
             ON       stufo.ufonumser = stlit.ufonumser
    WHERE    ufocod BETWEEN 0 AND 99999
         AND litdis = 'O'
    GROUP BY 1,2
    ORDER BY ufocod
    Voici les nouveaux messages d'erreur :

    Msg*4104, Niveau*16, État*1, Ligne*1
    L'identificateur en plusieurs parties "parlit.litnumser" ne peut pas être lié.
    Msg*130, Niveau*15, État*1, Ligne*1
    Impossible d'exécuter une fonction d'agrégation sur une expression comportant un agrégat ou une sous-requête.
    Valoji .

  5. #5
    Membre expérimenté
    Inscrit en
    Février 2009
    Messages
    224
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 224
    Par défaut
    Bonjour,
    tout d'abord je ne peux que vous inciter à lire la documentation SQL Server sur l'instruction SELECT : http://msdn.microsoft.com/fr-fr/library/ms189499.aspx. Vous serez ainsi en mesure de mieux ciomprendre ce qu'il est possible ou non de faire.
    En lisant votre requete j'ai remarqué:
    Il faut indiquer le nom des colonnes sur lesquelles vous faite le group by, donc dans votre cas:
    Ensuite et c'est cela votre problème: il n'est pas possible de faire le cumul : calcul d'agrégat/CASE/calcul d'agrégat. Il est donc nécessaire d'écrire différement votre requête.
    Pour simplifier l'écriture de votre requête pensez aux tables CTE, aux vues et aux fonctions.

  6. #6
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 999
    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 999
    Billets dans le blog
    6
    Par défaut
    Msg*4104, Niveau*16, État*1, Ligne*1
    L'identificateur en plusieurs parties "parlit.litnumser" ne peut pas être lié.
    C'est normal, relisez vous... tantôt vous avez mis PARLI (sans t) et d'autres fois PARLIT avec un T...

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

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

Discussions similaires

  1. sql server 2005:syntaxe ajout, modification, suppression
    Par wassim hamrouni dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 11/04/2011, 12h11

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