Précédent   Forum des professionnels en informatique > Bases de données > Langage SQL
Langage SQL Forum d'entraide sur le langage SQL et sur les questions liées à la conception de schéma (DDL). Cours SQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 16/05/2011, 10h00   #1
Invité de passage
 
Inscription : mars 2010
Messages : 46
Détails du profil
Informations forums :
Inscription : mars 2010
Messages : 46
Points : 4
Points : 4
Par défaut fusionner requête SQL avec conditions différentes

Bonjour,
je rencontre un problème avec une requête que j'essaie de faire, mais je ne sais pas si c'est possible.


Code :
1
2
3
4
5
6
7
8
SELECT RIGHT(LEFT(`start_date`,7),2) AS Mois
,ROUND(SUM(item_total_cost),2) AS 'ECM (EUROS)' 
FROM data_txt 
WHERE company='Entreprise FRANCE' a
nd (order_status='Confirmed' OR order_status='Delivered') 
AND course_number_1 LIKE 'EC%' 
AND course_number_2 NOT LIKE 'DIF%' 
GROUP BY RIGHT(LEFT(`start_date`,7),2)

Code :
1
2
3
4
5
6
7
SELECT RIGHT(LEFT(`start_date`,7),2) AS Mois
,ROUND(SUM(item_total_cost),2) AS 'DIFF (EUROS)' 
FROM data_txt 
WHERE company='Entreprise FRANCE' 
AND (order_status='Confirmed' OR order_status='Delivered') 
AND course_number_2 LIKE 'DIF%' 
GROUP BY RIGHT(LEFT(`start_date`,7),2)
La colonne commune est Mois, mais je voudrais obtenir le résultat suivant a partir de ces deux requêtes :

MOIS || ECM (EUROS) || DIFF (EUROS)

est-ce possible.

Merci d'avance pour les réponses.
breizhlama est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/05/2011, 10h05   #2
Membre Expert
 
Avatar de Yanika_bzh
 
Homme Yannick
Ingénieur Etudes & Developpements
Inscription : février 2006
Messages : 1 125
Détails du profil
Informations personnelles :
Nom : Homme Yannick
Localisation : France, Deux Sèvres (Poitou Charente)

Informations professionnelles :
Activité : Ingénieur Etudes & Developpements
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : février 2006
Messages : 1 125
Points : 1 670
Points : 1 670
Vous pouvez dans un premier temps faire une jointure entre ces 2 requetes

Bon courage
__________________
Dans la connaissance du monde, ceux qui ne savent rien en savent toujours autant que ceux qui n'en savent pas plus qu'eux. (Pierre Dac)
Yanika_bzh est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/05/2011, 10h08   #3
Membre Expert
 
Homme
Responsable de service informatique
Inscription : janvier 2009
Messages : 1 081
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 38
Localisation : France

Informations professionnelles :
Activité : Responsable de service informatique
Secteur : Boutique - Magasin

Informations forums :
Inscription : janvier 2009
Messages : 1 081
Points : 1 875
Points : 1 875
Bonjour,
Tu peux faire ceci:
Code SQL :
1
2
3
4
5
6
7
8
9
  SELECT RIGHT(LEFT(`start_date`, 7), 2) AS Mois
       , ROUND(SUM(case when course_number_1 LIKE 'EC%' AND course_number_2 NOT LIKE 'DIF%' then item_total_cost else 0 end), 2) AS 'ECM (EUROS)'
       , ROUND(SUM(case when course_number_2 LIKE 'DIF%'                                    then item_total_cost else 0 end), 2)
    FROM data_txt
   WHERE company = 'Entreprise FRANCE'
     AND (order_status = 'Confirmed' OR order_status = 'Delivered')
     AND ((course_number_1 LIKE 'EC%' AND course_number_2 NOT LIKE 'DIF%')
      OR (course_number_2 LIKE 'DIF%'))
GROUP BY RIGHT(LEFT(`start_date`, 7), 2)

Tatayo.
tatayo est actuellement connecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/05/2011, 10h19   #4
Membre Expert
 
Avatar de Yanika_bzh
 
Homme Yannick
Ingénieur Etudes & Developpements
Inscription : février 2006
Messages : 1 125
Détails du profil
Informations personnelles :
Nom : Homme Yannick
Localisation : France, Deux Sèvres (Poitou Charente)

Informations professionnelles :
Activité : Ingénieur Etudes & Developpements
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : février 2006
Messages : 1 125
Points : 1 670
Points : 1 670
Citation:
Envoyé par tatayo Voir le message
Tu peux faire ceci
Dans ce cas, autant enlever la redondance de filtre dans la clause WHERE, elle ne sert pas a grand-chose.
__________________
Dans la connaissance du monde, ceux qui ne savent rien en savent toujours autant que ceux qui n'en savent pas plus qu'eux. (Pierre Dac)
Yanika_bzh est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/05/2011, 10h33   #5
Membre Expert
 
Homme
Responsable de service informatique
Inscription : janvier 2009
Messages : 1 081
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 38
Localisation : France

Informations professionnelles :
Activité : Responsable de service informatique
Secteur : Boutique - Magasin

Informations forums :
Inscription : janvier 2009
Messages : 1 081
Points : 1 875
Points : 1 875
Citation:
Envoyé par Yanika_bzh Voir le message
Dans ce cas, autant enlever la redondance de filtre dans la clause WHERE, elle ne sert pas a grand chose
Pas forcément, rien ne dit qu'il n'existe pas des lignes dans la base ne correspondant pas aux critères, et l'énoncé n'indique pas si elles doivent être prises en compte ou pas.

Tatayo.
tatayo est actuellement connecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/05/2011, 10h58   #6
Membre Expert
 
Avatar de Yanika_bzh
 
Homme Yannick
Ingénieur Etudes & Developpements
Inscription : février 2006
Messages : 1 125
Détails du profil
Informations personnelles :
Nom : Homme Yannick
Localisation : France, Deux Sèvres (Poitou Charente)

Informations professionnelles :
Activité : Ingénieur Etudes & Developpements
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : février 2006
Messages : 1 125
Points : 1 670
Points : 1 670
Effectivement si rien ne l'indique
__________________
Dans la connaissance du monde, ceux qui ne savent rien en savent toujours autant que ceux qui n'en savent pas plus qu'eux. (Pierre Dac)
Yanika_bzh est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/05/2011, 14h09   #7
Invité de passage
 
Inscription : mars 2010
Messages : 46
Détails du profil
Informations forums :
Inscription : mars 2010
Messages : 46
Points : 4
Points : 4
En tout cas, merci beaucoup, je ne connaissais pas CASE en mysql. Et ça va grandement m'aider pour la suite

Merci beaucoup à tout le monde ^^
breizhlama est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/05/2011, 14h36   #8
Modérateur
 
Homme Fabien
Ingénieur d'études en décisionnel
Inscription : septembre 2008
Messages : 5 684
Détails du profil
Informations personnelles :
Nom : Homme Fabien
Âge : 34
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Ingénieur d'études en décisionnel
Secteur : Arts - Culture

Informations forums :
Inscription : septembre 2008
Messages : 5 684
Points : 10 442
Points : 10 442
Envoyer un message via ICQ à Waldar Envoyer un message via Skype™ à Waldar
Si start_date est bien au format date, on peut utiliser les fonctions dédiées :
Code :
1
2
DATE_FORMAT(start_date, %m)
EXTRACT(month FROM start_date)
__________________
Email : http://scr.im/waldar
Waldar est actuellement connecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 11h58.


 
 
 
 
Partenaires

Hébergement Web