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

MySQL Discussion :

Union de sous-requetes issues d'une même requete


Sujet :

MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    45
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mars 2011
    Messages : 45
    Par défaut Union de sous-requetes issues d'une même requete
    Bonjour,

    Je n'arrive pas à savoir s'il est possible à partir d'une requête de créer une union de 2 sous requêtes de cette requête. Et si cette structure est possible quelle doit être son architecture.

    Plus précisément:
    1) Je dispose d'une requête de départ , soit R1, construite à partir de plusieurs tables jointes.
    2) Je construis 2 sous requêtes s'appuyant sur R1 qui permettent d'extraire chacune les mêmes champs CH1,CH2,..CHn.
    Les méthodes d'extraction de ces champs étant différentes, il est nécessaire de bâtir deux sous requêtes. Soit SR1 et SR2 ces deux sous requêtes.
    3) Je voudrais faire une requête union de SR1 et SR2 pour obtenir le jeu de CH1,CH2,...CHn résultant de leur deux calculs.

    Ma question: Si une telle construction est possible, quelle doit être sa structure.

    Merci d'avance pour votre éclairage.

    Caplande

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 628
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 628
    Billets dans le blog
    10
    Par défaut
    Je ne vois aucune difficulté particulière faites tout simplement SR1 union(all) SR2

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    45
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mars 2011
    Messages : 45
    Par défaut
    Citation Envoyé par escartefigue Voir le message
    Je ne vois aucune difficulté particulière faites tout simplement SR1 union(all) SR2
    Je ne sais pas relier l'union des 2 sous-requêtes à l'unique requête R1 dont toutes les deux dépendent. En effet R1 contient des JOIN et je ne peux la formuler qu'une seule fois alors qu'elle est la 'source' des 2 sous-requêtes.

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

    En ayant la requête, ce serait plus facile.

    Comment est utilisée votre requête R1 ? en clause EXISTS, en jointure ? ...

    vous pouvez faire votre UNION entre SR1 et SR2 dans une sous requete, et ajouter R1 ensuite.

  5. #5
    Membre averti
    Homme Profil pro
    Inscrit en
    Mars 2011
    Messages
    45
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mars 2011
    Messages : 45
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message
    Bonjour,

    En ayant la requête, ce serait plus facile.

    Comment est utilisée votre requête R1 ? en clause EXISTS, en jointure ? ...

    vous pouvez faire votre UNION entre SR1 et SR2 dans une sous requete, et ajouter R1 ensuite.
    Je ne voulais insérer requête qui me pose pb car elle est un peu compliquée. Je la joins néanmoins ci-dessous, si vous avez la patience d'y jeter un oeil, merci d'avance pour votre aide:
    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
    SELECT *
    FROM (
    	(SELECT pa_id , dc , CONCAT(IF(na_id = 4, 'PRT-', 'HPRT-'),'2015','-',im_id,'-',pa_id) AS cle , IF(pa_id = '1' , om_mtt , IF(pa_id = '3' , om_mtt/2 , 0)) AS mtt
    		FROM mySelect1)
    	UNION
    	(SELECT pa_id , dc , CONCAT(IF(na_id = 4, 'PRT-', 'HPRT-'),'2015','-',im_id,'-',pa_id) AS cle , IF(pa_id = '2' , om_mtt , IF(pa_id = '3' , om_mtt/2 , 0)) AS mtt
    		FROM mySelect1)
    ) AS monSelect2
    FROM (
    	SELECT 
    		YEAR(e.oe_date_ope) AS annee, 
    		m.om_dc AS dc, 
    		e.oe_na_id AS na_id,
    		e.oe_im_id AS im_id,
    		c.cp_pa_id AS pa_id,
    		m.om_mtt AS om_mtt
    	FROM ope_entetes e 
    	LEFT JOIN ope_mtts m ON e.oe_id = m.om_oe_id 
    	LEFT JOIN comptes c ON m.om_cp_id = c.cp_id 
    	HAVING annee <= 2015
    ) AS monSelect1
    WHERE pa_id <> 3;

  6. #6
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 628
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 628
    Billets dans le blog
    10
    Par défaut
    il faut faire une CTE avec la requete que vous avez nommée "myselect1" et "myselect2" puis faire la requete union qui utilise ces tables temporaires

Discussions similaires

  1. SELECT et UPDATE dans une même requete
    Par gael dans le forum Langage SQL
    Réponses: 6
    Dernier message: 24/01/2011, 01h57
  2. 2 order by différents dans une même requete
    Par Christophe P. dans le forum SQL
    Réponses: 5
    Dernier message: 12/06/2007, 14h03
  3. [AJAX] deux requetes ajax dans une même page
    Par mitmit dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 02/05/2007, 12h52
  4. [SQL2K] Deux count dans une même requete
    Par maitrebn dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 14/02/2007, 17h12
  5. [ACCESS] - Requete issue d'une liste à selection multiple
    Par fredhali2000 dans le forum Access
    Réponses: 4
    Dernier message: 22/02/2006, 15h33

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