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 :

[sql2000] Group By & Getdate()


Sujet :

MS SQL Server

  1. #1
    Nouveau membre du Club
    Inscrit en
    Décembre 2003
    Messages
    35
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Décembre 2003
    Messages : 35
    Points : 38
    Points
    38
    Par défaut [sql2000] Group By & Getdate()
    Salut tlm,


    j'ai une requête assez longue où je souhaite ajouter des colonnnes avec des dates.

    Après l'avoir tournée dans tous les sens, j'ai isolé ce qui pose problème.
    Est-ce que quelqu'un peut me dire pourquoi ce qui suit ne marche pas.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT		YEAR(GETDATE())
    FROM		mouvements
    GROUP BY	YEAR(GETDATE())
     
    Serveur : Msg 164, Niveau 15, État 1, Ligne 3
    Les expressions GROUP BY doivent faire référence à des noms de colonnes figurant dans la liste de sélection.

  2. #2
    Membre actif
    Inscrit en
    Février 2006
    Messages
    185
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 185
    Points : 224
    Points
    224
    Par défaut
    on ne groupe que sur des colonnes existantes. Toi tu es en train de grouper sur le resultat d'une fonction

  3. #3
    Nouveau membre du Club
    Inscrit en
    Décembre 2003
    Messages
    35
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Décembre 2003
    Messages : 35
    Points : 38
    Points
    38
    Par défaut
    Je suis d'accord avec toi.

    Mais je comprends pas pourquoi ce qui suit fonctionne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT     Mouvements.num_soc + ' ' + CAST(Mouvements.num_contrat AS varchar) AS contrat, Mouvements.pdv, 
                          CAST(ROUND(SUM(Mouvements.prorata), 2) AS decimal(10, 2)) AS prorata, LEFT(Mouvements.echeance, 2) 
                          + '/' + RIGHT(Mouvements.echeance, 2) + '/' + CAST(YEAR(GETDATE()) AS char(4)) AS echeance, Mouvements.AgenceNom, 
                          Mouvements.AgenceAdresse, Mouvements.AgenceVille
    FROM         Mouvements INNER JOIN
                          CotisVeh ON Mouvements.num_soc + ' ' + CAST(Mouvements.num_contrat AS varchar) = CotisVeh.Contrat
    GROUP BY Mouvements.num_soc + ' ' + CAST(Mouvements.num_contrat AS varchar), Mouvements.pdv, LEFT(Mouvements.echeance, 2) 
                          + '/' + RIGHT(Mouvements.echeance, 2) + '/' + CAST(YEAR(GETDATE()) AS char(4)), Mouvements.AgenceNom, 
                          Mouvements.AgenceAdresse, Mouvements.AgenceVille
    Généré dans Entreprise Manager

  4. #4
    Membre actif
    Inscrit en
    Février 2006
    Messages
    185
    Détails du profil
    Informations forums :
    Inscription : Février 2006
    Messages : 185
    Points : 224
    Points
    224
    Par défaut
    comme tu vois il ya les colonnes
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Mouvements.num_soc,Mouvements.num_contrat,Mouvements.pdv,Mouvements.pdv,Mouvements.AgenceNom
    provenant de la table mouvements.
    tu ne peux pas grouper sur des fonctions seulement; il faut que des colonnes y soient associées (celles provenant du select)

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

Discussions similaires

  1. syntaxe incorrecte avec mon getdate et Group By
    Par tibofo dans le forum Développement
    Réponses: 7
    Dernier message: 12/02/2009, 10h17
  2. [RaveReport] - Bloquer groupe sur une page
    Par muaddib dans le forum Rave
    Réponses: 3
    Dernier message: 25/02/2003, 17h21
  3. gestion des groupes
    Par muaddib dans le forum QuickReport
    Réponses: 3
    Dernier message: 31/12/2002, 12h01

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