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 :

Sélection de lignes avec regroupement des doublons [2012]


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    France
    Inscrit en
    Juillet 2016
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : France
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2016
    Messages : 76
    Par défaut Sélection de lignes avec regroupement des doublons
    Bonjour,

    Je rencontre un petit soucis dans la rédaction d'une requête et le regroupement de ses doublons.

    Je génére la requete suivante :
    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
     
    WITH R as (
    SELECT distinct	f.NUM_ENR
    				,f.DESIGN
    				,(sum(lbt.QTE*s.pump) over (partition by f.design)) cumul2
     
     
     
    from	T_FAMILLE_PIECE f
    	full join	t_piece p		on p.CLE_FAMILLE = f.NUM_ENR
    	full join	T_LIGNE_BT lbt	on lbt.CLE_ELEMENT = p.CLE_PIECE
    	left join	T_STOCK	s		on s.CLE_PIECE = p.CLE_PIECE
    	left join t_bt bt			on bt.NUM_BT =lbt.CLE_BT
    where lbt.TYPE_LIGNE_BT ='P'
    	and s.CLE_MAGASIN <>100000
    	and bt.DATE_DEB_REEL between  dateadd( MONTH ,-3,dateadd(day,0,DATEADD(MONTH, DATEDIFF(MONTH, '19000101', GETDATE()), '19000101')))
    							and		dateadd(day,0,DATEADD(MONTH, DATEDIFF(MONTH, '19000101', GETDATE()), '19000101'))
     
    union 
     
    SELECT distinct	f.NUM_ENR
    				,f.DESIGN
    				,(sum(lbt.COUT_2_PSEUDO_U) over (partition by f.design)) cumul2
     
    from	T_FAMILLE_PIECE f
    	full join	t_piece p		on p.CLE_FAMILLE = f.NUM_ENR
    	inner join T_MATRICULE_PIECE m on m.CLE_PIECE = p.CLE_PIECE
    	full join	T_LIGNE_BT lbt	on lbt.CLE_ELEMENT = m.NUM_PIECE_M
    	left join	T_STOCK	s		on s.CLE_PIECE = p.CLE_PIECE
    	left join t_bt bt			on bt.NUM_BT =lbt.CLE_BT
    where lbt.TYPE_LIGNE_BT ='M'
    	and s.CLE_MAGASIN <>100000
    	and bt.DATE_DEB_REEL between  dateadd( MONTH ,-3,dateadd(day,0,DATEADD(MONTH, DATEDIFF(MONTH, '19000101', GETDATE()), '19000101')))
    							and		dateadd(day,0,DATEADD(MONTH, DATEDIFF(MONTH, '19000101', GETDATE()), '19000101'))
     
     
    	)
     
    SELECT	NUM_ENR
    		,DESIGN
    		,cumul2/*
    		,SUM(CUMUL) OVER (order by CUMUL desc) as TOTCUMUL */
    		,cumul2 / SUM(CUMUL2) OVER () as 'pourcentage/tot'
    		,SUM(CUMUL2) OVER (order by CUMUL2 desc)  / SUM(CUMUL2) OVER () as TOTCUMUL2
     
    FROM R
    J'ai bien tenté de faire un group by :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT	NUM_ENR
    		,DESIGN
    		,SUM(cumul2)
    		,SUM(cumul2 / SUM(CUMUL2) OVER () ) as 'pourcentage/tot'
    		,SUM ( SUM(CUMUL2) OVER (order by CUMUL2 desc)  / SUM(CUMUL2) OVER () ) as TOTCUMUL2
    
    FROM R
    GROUP BY NUM_ENR
    		,DESIGN
    mais l'erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Msg*8120, Niveau*16, État*1, Ligne*44
    La colonne 'R.cumul2' n'est pas valide dans la liste de sélection parce qu'elle n'est pas contenue dans une fonction d'agrégation ou dans la clause GROUP BY.
    Msg*4109, Niveau*15, État*1, Ligne*44
    Les fonctions fenêtrées ne peuvent pas être employées dans le contexte d'une autre fonction en fenêtre ou d'un agrégat.
    Auriez vous une solution.. ?

    Cordialement,

  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 010
    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 010
    Billets dans le blog
    6
    Par défaut
    merci de poster le DDL des tables comme indiqué ici dans les regles de postage :
    https://www.developpez.net/forums/d9...vement-poster/

    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
    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,

    Vous pouvez peut être faire une CTE supplémentaire pour calculer vos agregats partiels, mais bon, je n'ai pas compris grand chose à ce que vous essayez de faire alors difficile d'être plus précis.

    Une jeu d'essai + résultat attendu seraient fort utiles pour mieux comprendre et donc mieux vous aider...

  4. #4
    Membre confirmé
    Homme Profil pro
    France
    Inscrit en
    Juillet 2016
    Messages
    76
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : France
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2016
    Messages : 76
    Par défaut
    Tout d'abord merci pour la réponse.

    Je ne savais pas que je pouvais formuler une double CTE... :
    https://blog.cellenza.com/data/sql-s...le-sql-server/

    Tout m'a l'air OK maintenant ! Merci pour la réponse

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

Discussions similaires

  1. [AC-2007] sélection de ligne avec condition et les supprimer
    Par Sangoku62000 dans le forum Access
    Réponses: 2
    Dernier message: 30/01/2012, 12h46
  2. [AC-2007] Fusion d’enregistrement avec suppression des doublons dans champs multivaleur
    Par Daniel-Gérald dans le forum VBA Access
    Réponses: 1
    Dernier message: 15/09/2011, 04h20
  3. Zone de liste déroulante avec regroupement des éléments
    Par Lincoln911 dans le forum VBA Access
    Réponses: 1
    Dernier message: 26/04/2010, 12h55
  4. Sélection de lignes qui ont des valeurs maximales
    Par sicnarf dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 31/10/2008, 15h42
  5. Pb sélection de lignes avec variables
    Par Aizen64 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 14/06/2007, 08h36

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