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

PL/SQL Oracle Discussion :

sélectionner le last valeur d'une colonne pour les id_clients en double


Sujet :

PL/SQL Oracle

  1. #1
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 56
    Par défaut sélectionner le last valeur d'une colonne pour les id_clients en double
    Bonjour,

    J'ai un problème avec le résultat de ma requête, en fait je fais un group by sur toutes les colonne de ma table mais je dois avoir au final des lignes sans id_client (colonne d'une table) en double et pour chaque id_client je garderai la ligne dont la valeur d'une autre colonne de la table est la plus récente.

    Autrement dit, mes doublons ne sont que sur la colonne id_client et moi je cherche à avoir une seule ligne pour chaque id_client ( supprimer les autres lignes qui portent le même id_client et ne garder qu'une seule qui sera celle dont la valeur d'une autre colonne XX est la plus récente.

    merci pour votre aide et j'espère que je me suis bien fait comprendre.

  2. #2
    Rédacteur

    Homme Profil pro
    Développeur et DBA Oracle
    Inscrit en
    Octobre 2006
    Messages
    878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur et DBA Oracle

    Informations forums :
    Inscription : Octobre 2006
    Messages : 878
    Par défaut
    Salut,

    peux-tu poster ta requête ?

    Salim.

  3. #3
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 56
    Par défaut
    la requete est très longue, elle est générée automatiquement par Analytics, moi je cherche à la modifier; voila le genre de résultat obtenu et moi parmi toute la liste de retour, je cherche à garder 10197252224 avec 4 septembre et supprimer la deuxième ligne.

    Merci pour ton aide

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
              Tableau  
     
    10197252224 3 septembre 2009 Clos 
    10197252224 4 septembre 2009 Clos

  4. #4
    Rédacteur

    Homme Profil pro
    Développeur et DBA Oracle
    Inscrit en
    Octobre 2006
    Messages
    878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur et DBA Oracle

    Informations forums :
    Inscription : Octobre 2006
    Messages : 878
    Par défaut
    1 solution sans fonction analytique
    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
     
    WITH t AS
         (SELECT 10197252224 NO, TO_DATE ('03-septembre-2009', 'dd-month-yyyy') dt,
                 'Clos' status
            FROM DUAL
          UNION ALL
          SELECT 10197252224, TO_DATE ('4-septembre-2009', 'dd-month-yyyy'),
                 'Clos'
            FROM DUAL)
    SELECT   NO, MAX (dt) dt , MAX (status)KEEP (DENSE_RANK LAST ORDER BY dt) status
        FROM t
    GROUP BY NO
     
     
     
                 NO DT         STAT
    --------------- ---------- ----
        10197252224 2009-09-04 Clos
     
     
    1 row selected.
    2 ième solution : avec fonction analytique
    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
     
    WITH t AS
         (SELECT 10197252224 NO, TO_DATE ('03-septembre-2009',
                                          'dd-month-yyyy') dt, 'Clos' status
            FROM DUAL
          UNION ALL
          SELECT 10197252224, TO_DATE ('4-septembre-2009', 'dd-month-yyyy'),
                 'Clos'
            FROM DUAL)
    SELECT NO, dt, status
      FROM (SELECT NO, dt, status,
                   ROW_NUMBER () OVER (PARTITION BY NO ORDER BY dt DESC) rn
              FROM t)
     WHERE rn = 1
     
                 NO DT         STAT
    --------------- ---------- ----
        10197252224 2009-09-04 Clos
     
     
    1 row selected.

  5. #5
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 56
    Par défaut
    Je t'en remercie beaucoup salim11, là tu me sauve la vie, je vais vite tester tes réponses dans le bloc de ma requête et voir ce que ça donne, je suis optimiste (j'espère que sont des fonctions qui fonctionneront sous oracle 10g).

    merci beaucoup.

  6. #6
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 56
    Par défaut
    Salim11,

    peux tu m'expliquer rapidement la syntaxe des fonctions que t'as utilisées ?:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    KEEP (DENSE_RANK LAST ORDER BY dt)
    ;
    je ne comprends pas bien comment l'intégrer dans le reste de ma requête car je me dispose de plusieurs colonnes ( j'ai donné l'exemple sur 3 colonnes).

  7. #7
    Rédacteur

    Homme Profil pro
    Développeur et DBA Oracle
    Inscrit en
    Octobre 2006
    Messages
    878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur et DBA Oracle

    Informations forums :
    Inscription : Octobre 2006
    Messages : 878
    Par défaut
    salut,
    MAX (STATUS)KEEP (DENSE_RANK LAST ORDER BY dt) : il va ramener le status qui correspond au dernier enregistrement ordonné par dt pour chaque groupe de no.


    Pour adapter ma requ^te à ton besoin : par exemple si tu as 3 autres champs( champ1,champ2,champ3)

    Requête devient :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT   NO, MAX (dt) dt , MAX (STATUS)KEEP (DENSE_RANK LAST ORDER BY dt) STATUS,
    MAX (champ1)KEEP (DENSE_RANK LAST ORDER BY dt)  champ1,
    MAX (champ2)KEEP (DENSE_RANK LAST ORDER BY dt) champ2,
    MAX (champ3)KEEP (DENSE_RANK LAST ORDER BY dt) champ3,
        FROM t
    GROUP BY NO

    Salim.

  8. #8
    Membre averti
    Inscrit en
    Janvier 2009
    Messages
    56
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 56
    Par défaut
    Merci beaucoup, c'est cool, c'est très fort.

    mon problème est résolu grâce à tes connaissance et ton aide, merci.

  9. #9
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Salim,

    KEEP FIRST / KEEP LAST font partie des fonctions analytiques !
    En tout cas elles sont rangées comme telles dans la doc Oracle.


    Saidna,

    Je n'aime pas spécialement me faire de la pub, mais j'ai écrit un petit sujet (en anglais) sur mon blog :
    http://www.waldar.org/blog/200904/yo...like-analytics

  10. #10
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Citation Envoyé par Waldar Voir le message
    ...
    KEEP FIRST / KEEP LAST font partie des fonctions analytiques !
    En tout cas elles sont rangées comme telles dans la doc Oracle.
    ...
    Salut Waldar,

    Je n'ai pas eu cette impression en lisant la doc d'Oracle
    FIRST and LAST are very similar functions. Both are aggregate and analytic functions that operate on a set of values from a set of rows that rank as the FIRST or LAST with respect to a given sorting specification

  11. #11
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Exact, c'est moi qui ait lu trop vite !

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

Discussions similaires

  1. [XL-2007] Extraire toutes les valeurs d'une Listbox pour les afficher dans un commentaire
    Par Didpa dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 16/07/2013, 18h12
  2. [MySQL] Recuperer les valeurs d'une bdd pour les ré-inserer en un ligne
    Par spawns dans le forum PHP & Base de données
    Réponses: 23
    Dernier message: 15/11/2012, 08h26
  3. Réponses: 4
    Dernier message: 04/05/2012, 17h23
  4. Réponses: 1
    Dernier message: 17/04/2011, 08h50
  5. Réponses: 8
    Dernier message: 06/12/2005, 11h33

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