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

SQL Oracle Discussion :

Fusionner des lignes qui ont les mêmes valeurs d'un champ


Sujet :

SQL Oracle

  1. #1
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    77
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 77
    Points : 59
    Points
    59
    Par défaut Fusionner des lignes qui ont les mêmes valeurs d'un champ
    Bonjour,

    J'ai une table qui peut avoir des redondances des données et je souhaite les fusionner.
    Ma table est de la forme : T(id, name, qty)

    Elle peut contenir des données du genre :
    (1, a, 2)
    (2, a, 3)


    et je souhaite avoir une seule ligne qui contient la somme des qty pour le même name
    par exemple (1, a, 5) .

    Pouvez vous m'aider à construire la requête.

    Merci d'avance.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select min(id) id, name, sum(qty)
    from T
    group by name

  3. #3
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    77
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 77
    Points : 59
    Points
    59
    Par défaut
    Merci pour votre réponse.

    Votre solution résout une partie du problème. Je souhaite également supprimer les anciennes lignes.

    Exemple :
    Je souhaite garder dans la table la ligne (1, a, 5)
    et supprimer les lignes (1, a, 2) et (2, a, 3).

    Peut-on le faire sans passer par une table intermédiaire?

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    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 453
    Points : 18 386
    Points
    18 386
    Par défaut
    On peut le faire en une commande avec MERGE :
    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
    create table t (id number(1), name varchar2(1), qty number(1))
    -- Table created.
     
    insert into t values (1, 'a', 2);
    -- 1 row created.
     
    insert into t values (2, 'a', 3);
    -- 1 row created.
     
    commit;
    -- Commit complete.
     
    select * from t;
            ID N        QTY
    ---------- - ----------
             1 a          2
             2 a          3
    -- 2 rows selected.
     
     merge into t t1
     using (  select min(id) as id
                   , name
                   , sum(qty) as qty
                from t
            group by name) t2
        on (t2.name = t1.name)
      when matched then
    update set t1.qty = t2.qty
    delete where (t1.id <> t2.id);
    -- 2 rows selected.
    -- Merge successfully completed.
     
    select * from t;
     
            ID N        QTY
    ---------- - ----------
             1 a          5
    -- 1 row selected.
     
    drop table t;
    -- Table dropped.

  5. #5
    Membre du Club
    Inscrit en
    Septembre 2008
    Messages
    77
    Détails du profil
    Informations forums :
    Inscription : Septembre 2008
    Messages : 77
    Points : 59
    Points
    59
    Par défaut
    Merci votre réponse

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 10/10/2014, 04h20
  2. Réponses: 3
    Dernier message: 08/03/2010, 13h36
  3. [XL-2003] supprimer des lignes qui ont les même valeurs
    Par Neptune64 dans le forum Excel
    Réponses: 1
    Dernier message: 09/08/2009, 00h30
  4. SELECT des lignes qui ont exactement 4 valeurs sur la colonne ?
    Par mamiberkof dans le forum Langage SQL
    Réponses: 8
    Dernier message: 03/01/2008, 15h00
  5. Réponses: 3
    Dernier message: 20/01/2007, 19h09

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