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 :

problème avec le groupage


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Congo-Kinshasa

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2013
    Messages : 3
    Par défaut problème avec le groupage
    Bonjour à Tous,
    Quelqu’un pourrais m’aide svp je travaille avec SQL Server 2008 R2
    J’ai une table qui contient vente de produit je voudrais étaler la vente de chaque mois alors
    Je Vais Une Requête du style
    SELECT CAST(MONTH(DateVente) as VARCHAR(2)) + '-' + CAST(YEAR(DateVente) as VARCHAR(4)) AS [Month],
    SUM([Montant]) as Total
    FROM [BDD].[dbo].[VEnte]
    GROUP BY CAST(MONTH(DateVente) as VARCHAR(2)) + '-' + CAST(YEAR(DateVente) as VARCHAR(4))
    Les données dans la table commencer à partir 01/11/2012 au 14/04/2013 seulement le Résultat ne pas Du tout exacte la somme du 01/04/2013 est ajouté à celle du 31/03/2013 je pu le constater en faisant ces requêtes :
    SELECT CAST(MONTH(DateVente) as VARCHAR(2)) + '-' + CAST(YEAR(DateVente) as VARCHAR(4)) AS [Month],
    SUM([Montant]) as Total
    FROM [BDD].[dbo].[VEnte]
    WHERE DateVente BETWEEN '2012-11-01' AND '2013-03-31'
    GROUP BY CAST(MONTH(DateVente) as VARCHAR(2)) + '-' + CAST(YEAR(DateVente) as VARCHAR(4))
    Et :
    SELECT CAST(MONTH(DateVente) as VARCHAR(2)) + '-' + CAST(YEAR(DateVente) as VARCHAR(4)) AS [Month],
    SUM([Montant]) as Total
    FROM [BDD].[dbo].[VEnte]
    WHERE DateVente BETWEEN '2012-11-01' AND '2013-04-14'
    GROUP BY CAST(MONTH(DateVente) as VARCHAR(2)) + '-' + CAST(YEAR(DateVente) as VARCHAR(4))
    Je suis puté si quelqu’un peux m’aider

  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
    Par défaut
    Bonjour,

    Quel est le type de la colonne DateVente ? contient elle la composante horaire ?
    Pouvez vous poster le résultat de vos requêtes ?

    Ps : merci d'utiliser les balises [code] pour rendre vos requêtes plus lisibles

  3. #3
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Congo-Kinshasa

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2013
    Messages : 3
    Par défaut
    le champ DateVente est datetime '2013-01-05 12:21:31.000'

  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
    Par défaut
    que donne cette requete :
    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 
    	DATEADD(
    		MONTH
    		,DATEDIFF(
    			MONTH
    			,0
    			,DateVente
    		)
    		,0
    	)
    	 AS [Month]
    	,
    	SUM([Montant]) as Total
    FROM [BDD].[dbo].[VEnte]
    GROUP BY 	
    	DATEADD(
    		MONTH
    		,DATEDIFF(
    			MONTH
    			,0
    			,DateVente
    		)
    		,0
    	)

  5. #5
    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
    Par défaut
    Je pense que votre requête est bonne, c'est votre vérification qui ne l'est pas :


    quand vous faites : WHERE DateVente BETWEEN '2012-11-01' AND '2013-03-31', les données du '2013-03-31 ne sont pas prises en compte, la borne est le '2013-03-31 00:00:00'

    pour vérifier, il faut donc mettre WHERE DateVente >= '2012-11-01' AND DateVente < '2013-04-01'

  6. #6
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2013
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Congo-Kinshasa

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Février 2013
    Messages : 3
    Par défaut
    merci beaucoup ça marche comme sur des roulettes

Discussions similaires

  1. VC++ Direct3D8, problème avec LPD3DXFONT et LPD3DTEXTURE8
    Par Magus (Dave) dans le forum DirectX
    Réponses: 3
    Dernier message: 03/08/2002, 11h10
  2. Problème avec [b]struct[/b]
    Par Bouziane Abderraouf dans le forum CORBA
    Réponses: 2
    Dernier message: 17/07/2002, 10h25
  3. Problème avec le type 'Corba::Any_out'
    Par Steven dans le forum CORBA
    Réponses: 2
    Dernier message: 14/07/2002, 18h48
  4. Problème avec la mémoire virtuelle
    Par Anonymous dans le forum CORBA
    Réponses: 13
    Dernier message: 16/04/2002, 16h10

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