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

Requêtes MySQL Discussion :

Résultats de 4 tables sur une même ligne dont 2 tables n'ont pas de lien entre-elles [MySQL-5.5]


Sujet :

Requêtes MySQL

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2011
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2011
    Messages : 40
    Points : 26
    Points
    26
    Par défaut Résultats de 4 tables sur une même ligne dont 2 tables n'ont pas de lien entre-elles
    Bonjour,

    J'essaye d'avoir via une requete SQL sur une même ligne : le nom du client (cli_nom AS nomclient), la somme des montants des produits où fac_campagne=prod_campagne et la somme des payements du client (WHERE pay_client=cli_id)

    table_produits => prod_id, prod_campagne, prod_montant
    table_payements => pay_id, pay_campagne, pay_client, pay_montant
    table_factures => fac_id, fac_prod, fac_client, fac_campagne
    table_clients => cli_id, cli_nom

    Est-ce que c'est possible ? En sachant qu'il n'y a pas de lien entre la table produit (qui liste les produits et leurs prix) et la table des clients.

    Merci d'avance pour votre aide,

    Sub

  2. #2
    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
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    comme ceci ?

    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
     
    SELECT cli_nom, MontantProduit, MontantPaiement
    FROM table_clients  cli
    LEFT JOIN (
        SELECT fac_client, SUM(prod_montant) as MontantProduit
        FROM table_factures fac
        INNER JOIN table_produits  pdt
            ON pdt.prod_campagne = fac.fac_campagne
        GROUP BY fac_client
    ) P
        ON P.fac_client = cli.cli_id
    LEFT JOIN (
        SELECT pay_client, SUM(pay_montant) AS MontantPaiement
        FROM table_payements 
        GROUP BY pay_client
    ) Pa
        ON Pa.pay_client = cli.cli_id

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2011
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2011
    Messages : 40
    Points : 26
    Points
    26
    Par défaut
    Merci pour ta réponse.

    Pour l'instant cela me donne bien 3 colonnes de données avec la première qui contient le nom du client mais les deux autres "MontantPaiement" et "MontantProduit" affichent NULL.

    Mais je suis content qu'une solution est possible. Je me concentre là-dessus et dès que j'ai la solution, je viens la poster.

    Bonne soirée,

    Sub

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    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 136
    Points : 38 561
    Points
    38 561
    Billets dans le blog
    9
    Par défaut
    Bonsoir,

    Si les montants sont null, c'est que les critères de jointures ne trouvent pas de correspondance.

    Par exemple dans le cas où certains clients n'ont pas de facture, ou bien que les colonnes utilisées pour les jointures ne sont pas les bonnes.
    Par exemple : est-ce que la colonne fac_client de la table facture est bien la même que la colonne cli_id de la table client

    Si vous ne souhaitez que les clients ayant des factures payées, alors remplacer les jointures outer par des jointures inner

  5. #5
    Expert éminent sénior Avatar de Artemus24
    Homme Profil pro
    Agent secret au service du président Ulysses S. Grant !
    Inscrit en
    Février 2011
    Messages
    6 381
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Agent secret au service du président Ulysses S. Grant !
    Secteur : Finance

    Informations forums :
    Inscription : Février 2011
    Messages : 6 381
    Points : 19 065
    Points
    19 065
    Par défaut
    Salut à tous.

    Je n'ai pas bien compris le rôle joué par "campagne" dans votre base de données.
    J'ai supposé que c'était une campagne commerciale et de ce fait, c'est une subdivision de produit.
    Autrement dit, pour un même produit, vous avez plusieurs campagnes.

    Voici ce que je propose :
    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
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    --------------
    SET AUTOCOMMIT = 0
    --------------
     
    --------------
    START TRANSACTION
    --------------
     
    --------------
    DROP DATABASE IF EXISTS `base`
    --------------
     
    --------------
    CREATE DATABASE `base`
        DEFAULT CHARACTER SET `latin1`
        DEFAULT COLLATE       `latin1_general_ci`
    --------------
     
    --------------
    DROP TABLE IF EXISTS `tab_client`
    --------------
     
    --------------
    CREATE TABLE `tab_client`
    ( `cli_id`   integer unsigned NOT NULL auto_increment primary key,
      `cli_nom`  varchar(255)     NOT NULL
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `tab_client` (`cli_nom`) values
      ('albert'),
      ('bertrand'),
      ('charles'),
      ('didier'),
      ('eric')
    --------------
     
    --------------
    select * from tab_client
    --------------
     
    +--------+----------+
    | cli_id | cli_nom  |
    +--------+----------+
    |      1 | albert   |
    |      2 | bertrand |
    |      3 | charles  |
    |      4 | didier   |
    |      5 | eric     |
    +--------+----------+
    --------------
    DROP TABLE IF EXISTS `tab_produit`
    --------------
     
    --------------
    CREATE TABLE `tab_produit`
    ( `prod_id`        integer unsigned NOT NULL,
      `prod_campagne`  integer unsigned NOT NULL,
      `prod_montant`   decimal(15,2)    NOT NULL,
      primary key (`prod_id`,`prod_campagne`)
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `tab_produit` (`prod_id`,`prod_campagne`,`prod_montant`) values
      (1, 101, 12.00), (1, 102, 11.00), (1, 103, 10.00),
      (2, 101, 33.00), (2, 102, 32.00), (2, 103, 31.00),
      (3, 101, 17.00), (3, 102, 16.00), (3, 103, 15.00),
      (4, 101, 45.00), (4, 102, 44.00), (4, 103, 43.00),
      (5, 101,  5.00), (5, 102,  4.00), (5, 103,  3.00),
      (6, 101,  9.00), (6, 102,  8.00), (6, 103,  7.00),
      (7, 101, 21.00), (7, 102, 20.00), (7, 103, 19.00)
    --------------
     
    --------------
    select * from tab_produit
    --------------
     
    +---------+---------------+--------------+
    | prod_id | prod_campagne | prod_montant |
    +---------+---------------+--------------+
    |       1 |           101 |        12.00 |
    |       1 |           102 |        11.00 |
    |       1 |           103 |        10.00 |
    |       2 |           101 |        33.00 |
    |       2 |           102 |        32.00 |
    |       2 |           103 |        31.00 |
    |       3 |           101 |        17.00 |
    |       3 |           102 |        16.00 |
    |       3 |           103 |        15.00 |
    |       4 |           101 |        45.00 |
    |       4 |           102 |        44.00 |
    |       4 |           103 |        43.00 |
    |       5 |           101 |         5.00 |
    |       5 |           102 |         4.00 |
    |       5 |           103 |         3.00 |
    |       6 |           101 |         9.00 |
    |       6 |           102 |         8.00 |
    |       6 |           103 |         7.00 |
    |       7 |           101 |        21.00 |
    |       7 |           102 |        20.00 |
    |       7 |           103 |        19.00 |
    +---------+---------------+--------------+
    --------------
    DROP TABLE IF EXISTS `tab_paiement`
    --------------
     
    --------------
    CREATE TABLE `tab_paiement`
    ( `pay_id`        integer unsigned NOT NULL auto_increment primary key,
      `pay_campagne`  integer unsigned NOT NULL,
      `pay_client`    integer unsigned NOT NULL,
      `pay_montant`   decimal(15,2)    NOT NULL,
      CONSTRAINT `FK_PAIEMENT_CLIENT`  FOREIGN KEY (`pay_client`) REFERENCES `tab_client` (`cli_id`) ON DELETE CASCADE ON UPDATE CASCADE
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `tab_paiement` (`pay_campagne`,`pay_client`,`pay_montant`) values
      (101, 1, 12.00), (102, 1, 16.00), (103, 1,  3.00),
      (101, 2, 12.00), (102, 2, 16.00), (103, 2,  7.00),
      (101, 3, 33.00), (102, 3, 44.00), (103, 3, 14.00),
      (101, 4, 33.00), (102, 4, 44.00), (103, 4, 19.00),
      (101, 5, 17.00), (102, 5,  4.00), (103, 5, 19.00)
    --------------
     
    --------------
    select * from tab_paiement
    --------------
     
    +--------+--------------+------------+-------------+
    | pay_id | pay_campagne | pay_client | pay_montant |
    +--------+--------------+------------+-------------+
    |      1 |          101 |          1 |       12.00 |
    |      2 |          102 |          1 |       16.00 |
    |      3 |          103 |          1 |        3.00 |
    |      4 |          101 |          2 |       12.00 |
    |      5 |          102 |          2 |       16.00 |
    |      6 |          103 |          2 |        7.00 |
    |      7 |          101 |          3 |       33.00 |
    |      8 |          102 |          3 |       44.00 |
    |      9 |          103 |          3 |       14.00 |
    |     10 |          101 |          4 |       33.00 |
    |     11 |          102 |          4 |       44.00 |
    |     12 |          103 |          4 |       19.00 |
    |     13 |          101 |          5 |       17.00 |
    |     14 |          102 |          5 |        4.00 |
    |     15 |          103 |          5 |       19.00 |
    +--------+--------------+------------+-------------+
    --------------
    DROP TABLE IF EXISTS `tab_facture`
    --------------
     
    --------------
    CREATE TABLE `tab_facture`
    ( `fac_id`        integer unsigned NOT NULL auto_increment primary key,
      `fac_prod`      integer unsigned NOT NULL,
      `fac_client`    integer unsigned NOT NULL,
      `fac_campagne`  integer unsigned NOT NULL,
      CONSTRAINT `FK_FACTURE_PRODUIT` FOREIGN KEY (`fac_prod`,`fac_campagne`) REFERENCES `tab_produit` (`prod_id`,`prod_campagne`) ON DELETE CASCADE ON UPDATE CASCADE,
      CONSTRAINT `FK_FACTURE_CLIENT`  FOREIGN KEY (`fac_client`)              REFERENCES `tab_client`  (`cli_id`)                  ON DELETE CASCADE ON UPDATE CASCADE
    ) ENGINE=InnoDB
      DEFAULT CHARSET=`latin1` COLLATE=`latin1_general_ci`
      ROW_FORMAT=COMPRESSED
    --------------
     
    --------------
    insert into `tab_facture` (`fac_prod`,`fac_client`,`fac_campagne`) values
      (1, 1, 101), (1, 2, 101),
      (2, 3, 101), (2, 4, 101),
      (3, 5, 101), (3, 1, 102), (3, 2, 102),
      (4, 3, 102), (4, 4, 102),
      (5, 5, 102), (5, 1, 103),
      (6, 2, 103), (6, 3, 103),
      (7, 4, 103), (7, 5, 103)
    --------------
     
    --------------
    select * from tab_facture
    --------------
     
    +--------+----------+------------+--------------+
    | fac_id | fac_prod | fac_client | fac_campagne |
    +--------+----------+------------+--------------+
    |      1 |        1 |          1 |          101 |
    |      2 |        1 |          2 |          101 |
    |      3 |        2 |          3 |          101 |
    |      4 |        2 |          4 |          101 |
    |      5 |        3 |          5 |          101 |
    |      6 |        3 |          1 |          102 |
    |      7 |        3 |          2 |          102 |
    |      8 |        4 |          3 |          102 |
    |      9 |        4 |          4 |          102 |
    |     10 |        5 |          5 |          102 |
    |     11 |        5 |          1 |          103 |
    |     12 |        6 |          2 |          103 |
    |     13 |        6 |          3 |          103 |
    |     14 |        7 |          4 |          103 |
    |     15 |        7 |          5 |          103 |
    +--------+----------+------------+--------------+
    --------------
    select t1.nom_client, total_produit, total_paiement,
           case abs(total_produit - total_paiement) when 0.00 then 'ok' else 'différence' end as controle
     
    from (
        select      cli_id, cli_nom as nom_client, sum(prod_montant) as total_produit
              from  tab_produit
     
        inner join  tab_facture
                on  fac_campagne = prod_campagne
               and  fac_prod     = prod_id
     
        inner join  tab_client
                on  cli_id = fac_client
     
          group by  cli_id, cli_nom
    ) as t1
     
    left outer join (
        select      cli_id, cli_nom as nom_client, sum(pay_montant) as total_paiement
     
              from  tab_paiement
     
        inner join  tab_facture
                on  fac_campagne = pay_campagne
               and  fac_client   = pay_client
     
        inner join  tab_client
                on  cli_id = pay_client
     
          group by  cli_id, cli_nom
    ) as t2
    on  t2.cli_id = t1.cli_id
    --------------
     
    +------------+---------------+----------------+------------+
    | nom_client | total_produit | total_paiement | controle   |
    +------------+---------------+----------------+------------+
    | albert     |         31.00 |          31.00 | ok         |
    | bertrand   |         35.00 |          35.00 | ok         |
    | charles    |         84.00 |          91.00 | différence |
    | didier     |         96.00 |          96.00 | ok         |
    | eric       |         40.00 |          40.00 | ok         |
    +------------+---------------+----------------+------------+
    --------------
    COMMIT
    --------------
     
    --------------
    SET AUTOCOMMIT = 1
    --------------
     
    Appuyez sur une touche pour continuer...
    S'il y a quelque chose qui ne vous convient pas, vous me l'indiquez !

    @+
    Si vous êtes de mon aide, vous pouvez cliquer sur .
    Mon site : http://www.jcz.fr

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2011
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2011
    Messages : 40
    Points : 26
    Points
    26
    Par défaut
    Parfait, merci beaucoup

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

Discussions similaires

  1. Requête deux résultats sur une même ligne
    Par delaio dans le forum Langage SQL
    Réponses: 4
    Dernier message: 12/02/2012, 12h10
  2. Résultat de 2 requêtes sur une même ligne
    Par cgone dans le forum SQL
    Réponses: 1
    Dernier message: 20/04/2007, 17h17
  3. Résultat d'un champ sur la même ligne
    Par laurent35 dans le forum Access
    Réponses: 11
    Dernier message: 30/10/2005, 20h33
  4. Aligner du texte à gauche et à droite sur une même ligne ?
    Par pontus21 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 12/04/2005, 11h25
  5. 2 éléments sur une même ligne
    Par ben_iap dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 24/11/2004, 17h27

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