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 :

Utilisation des alias dans le SELECT d'une requête


Sujet :

Développement SQL Server

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    55
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 55
    Points : 35
    Points
    35
    Par défaut Utilisation des alias dans le SELECT d'une requête
    Bonjour à tous,

    Voici mon problème :

    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
     
    SELECT
    ...
    (CASE 
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'OEM' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CTR'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P' AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P') ) )
     
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'SAVC' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CMM'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P'
    AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P')) )
     
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'SAVM' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CMM'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P'
    AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P')) )
     END) as MANUEL,
     
    (select DOC_REVNUMBER from R5DOCUMENTS where DOC_CODE = 
    (CASE 
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'OEM' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CTR'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P' AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P') ) )
     
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'SAVC' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CMM'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P'
    AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P')) )
     
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'SAVM' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CMM'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P'
    AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P')) )
     END) ) as REV_NUMBER
     
    FROM
    ...
    WHERE
    ...
    Je voudrais le résumé en :

    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
     
    SELECT
    ...
    (CASE 
     
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'OEM' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CTR'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P' AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P') ) )
     
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'SAVC' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CMM'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P'
    AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P')) )
     
    WHEN dbo.REPCUSTOMATTRIB( evt.EVT_CODE, '', 'REGCAT', 'EVNT', 'R5' ) = 'SAVM' THEN 
    (SELECT TOP 1 DAE_DOCUMENT FROM R5DOCENTITIES INNER JOIN R5DOCUMENTS ON DOC_CODE = DAE_DOCUMENT 
    WHERE DOC_CLASS='CMM'AND DAE_RENTITY='OBJ' AND DAE_RTYPE='P'
    AND DAE_CODE = ( evt.EVT_UDFCHAR23 + '#' + (SELECT OBJ_ORG FROM R5OBJECTS WHERE OBJ_CODE = evt.EVT_UDFCHAR23 AND OBJ_OBRTYPE ='P')) )
     END) as MANUEL,
     
    (select DOC_REVNUMBER from R5DOCUMENTS where DOC_CODE = MANUEL) as REV_NUMBER
     
    FROM
    ...
    WHERE
    ...
    Mais là :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Nom de colonne non valide*: 'MANUEL'.
    Comment puis je-faire ?
    Car le mettre 2 fois n'est absolument pas optimisé...

    Merci d'avance.

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    C'est parce que vous avez oublié les quotes à la ligne suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (SELECT DOC_REVNUMBER FROM R5DOCUMENTS WHERE DOC_CODE = 'MANUEL') AS REV_NUMBER
    Cela dit votre requête est horrible et doit être purifiable ...
    Postez donc le code complet et la structure des tables impliquées si vous souhaitez que nous vous aidions à le faire

    @++

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    55
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 55
    Points : 35
    Points
    35
    Par défaut
    Non ce n'est pas les quotes car MANUEL est un allias de colonne... et je voudrais lui dire que DOC_CODE = l'allias de colonne MANUEL

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

Discussions similaires

  1. Utilisation des alias dans la clause WHERE d'une requête SELECT
    Par OursRêveur dans le forum MS SQL Server
    Réponses: 14
    Dernier message: 13/07/2013, 04h34
  2. [AC-2003] Message de confirmation des modifications dans le résultat d'une requête
    Par Kaera dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 18/05/2012, 10h59
  3. Troncature des résultats dans l'output d'une requête SQL
    Par thisistheend dans le forum PL/SQL
    Réponses: 3
    Dernier message: 29/04/2011, 15h29
  4. [MySQL] Utilisation des alias dans une requête
    Par methodman225 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 29/09/2008, 12h55
  5. [Oracle] utilisation des alias dans le where
    Par seddik_saber dans le forum Langage SQL
    Réponses: 4
    Dernier message: 11/09/2007, 11h18

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