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 :

Problème d'union


Sujet :

SQL Oracle

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    102
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Janvier 2006
    Messages : 102
    Par défaut Problème d'union
    j' ai crée une requete basée sur plusieur requetes et liées par instruction union
    mais ne marche pas le compilateur comme ne reconnait pas l'instruction UNION
    voila mon code :

    alors que chaque requete marche toute seule.

    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
    create or replace view v_opendailyresult as
      select (b.risk ||' '||b.libelle_a) as riskcenter,sum(a.mtm_pl) as cash,0 as future,0 as inventorie,0 as freit,0 as forex
        from dpl_posit a,risk b
        where a.risk=b.risk
        group by b.risk,b.libelle_a
        order by b.risk,b.libelle_a
     
    UNION
     
      select (b.risk ||' '||b.libelle_a) as riskcenter,0 as cash,sum(c.mkt_price)as future,0 as inventorie,0 as freit,0 as forex
        from dpl_futures c,risk b
        where c.risk=b.risk
        group by b.risk,b.libelle_a
        order by b.risk,b.libelle_a  
     
    union
     
       select (b.risk ||' '||b.libelle_a) as riskcenter,0 as cash,0 as future,sum(d.mkt_prime) as options,0 as inventorie,0 as freit,0 as forex
        from dpl_options d,risk b
        where d.risk=b.risk
        group by b.risk,b.libelle_a
        order by b.risk,b.libelle_a   
     
    union
     
       select (b.risk ||' '||b.libelle_a) as riskcenter,0 as cash,0 as future,0 as options,sum(e.mkt_price)as inventorie,0 as freit,0 as forex
        from dpl_stock e,risk b
        where e.risk=b.risk
        group by b.risk,b.libelle_a
        order by b.risk,b.libelle_a      
     
    union
     
       select (b.risk ||' '||b.libelle_a) as riskcenter,0 as cash,0 as future,0 as options,0 as inventorie,sum(f.mkt_price) as freit,0 as forex
        from dpl_fret f,risk b
        where f.risk=b.risk
        group by b.risk,b.libelle_a
        order by b.risk,b.libelle_a     
     
    union
     
       select (b.risk ||' '||b.libelle_a) as riskcenter,0 as cash,0 as future,0 as options,0 as inventorie,0 as freit,sum(g.mkt_price)as forex
        from dpl_forex g,risk b
        where g.risk=b.risk
        group by b.risk,b.libelle_a
        order by b.risk,b.libelle_a ;

    merci

  2. #2
    Membre expérimenté Avatar de DAB.cz
    Inscrit en
    Octobre 2006
    Messages
    221
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 221
    Par défaut
    Une fois "order by":

    non:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select ...
      from ...
      order by ...
    union
    select ...
      from ...
      order by ...
    oui:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select ...
      from ...
    union
    select ...
      from ...
    order by ...

  3. #3
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Par défaut
    Comme ce n'est pas forcément top explicite... DAB.cz veut dire que dans une UNION, on a droit à une seule clause ORDER BY pour l'ensemble des SELECT unionés ; cette clause ORDER BY doit obligatoirement s'écrire dans le dernier SELECT.

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Antoun Voir le message
    l'ensemble des SELECT unionés ;
    Néologisme osé !
    Pourquoi ne pas essayer simplement avec l'ensemble des SELECT unis ?

  5. #5
    Membre expérimenté Avatar de DAB.cz
    Inscrit en
    Octobre 2006
    Messages
    221
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 221
    Par défaut
    Citation Envoyé par Antoun Voir le message
    Comme ce n'est pas forcément top explicite... DAB.cz veut dire que dans une UNION, on a droit à une seule clause ORDER BY pour l'ensemble des SELECT unionés ; cette clause ORDER BY doit obligatoirement s'écrire dans le dernier SELECT.
    Merci pour l'explication; plus précisément: pas dans le dernier SELECT, mais après.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    (select 1 a
      from dual)
    union
    (select 2 a
      from dual)
    order by a;

  6. #6
    Rédacteur/Modérateur

    Avatar de Antoun
    Homme Profil pro
    Architecte décisionnel
    Inscrit en
    Octobre 2006
    Messages
    6 284
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte décisionnel
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2006
    Messages : 6 284
    Par défaut
    Citation Envoyé par DAB.cz Voir le message
    Merci pour l'explication; plus précisément: pas dans le dernier SELECT, mais après.
    Tu as raison, mais c'est plus facile à expliquer comme ça...

Discussions similaires

  1. Problème de UNION
    Par zooffy dans le forum Langage SQL
    Réponses: 2
    Dernier message: 22/08/2006, 12h00
  2. Problème d'Union de chaïne
    Par Oberown dans le forum Requêtes
    Réponses: 5
    Dernier message: 13/01/2006, 14h20
  3. Problème d'UNION et de chaine
    Par Oberown dans le forum Requêtes
    Réponses: 2
    Dernier message: 07/01/2006, 13h43
  4. petit problème d'union
    Par poussinphp dans le forum Langage
    Réponses: 2
    Dernier message: 17/08/2005, 10h39
  5. Problème avec UNION et WHERE
    Par portu dans le forum Langage SQL
    Réponses: 13
    Dernier message: 20/04/2005, 11h29

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