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 :

Jointure entre deux tables avec close WHERE


Sujet :

Requêtes MySQL

  1. #1
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut Jointure entre deux tables avec close WHERE
    Salam ; j'ai une requête de jointure entre deux table qui retourne un jeux d'enregistrement. une fois que j'ajoute des paramètres avec la close WHERE sa génère un message d'erreur.
    requête:
    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
     
    <?php
    $resem=$cbd->prepare('SELECT 	
              m.ns,
    	COALESCE((DATE_FORMAT(datedec,"%U")),0) AS NS,
    	YEAR(c.datedec) AS Annee,
     
    	COALESCE((sum(c.m) + sum(c.m1) + sum(c.m2) + sum(c.m3) + sum(c.m4) + sum(c.m5) + sum(c.m6) + sum(c.m7) + sum(c.m8)), 0) AS Total_M,
    	COALESCE((sum(c.f) + sum(c.f1) + sum(c.f2) + sum(c.f3) + sum(c.f4) + sum(c.f5) + sum(c.f6) + sum(c.f7) + sum(c.f8)), 0) AS Total_F,
     
    	COALESCE((sum(c.m) + sum(c.m1) + sum(c.m2) + sum(c.m3) + sum(c.m4) + sum(c.m5) + sum(c.m6) + sum(c.m7) + sum(c.m8) + sum(c.f) + sum(c.f1) + sum(c.f2) + sum(c.f3) + sum(c.f4) + sum(c.f5) + sum(c.f6) + sum(c.f7) + sum(c.f8)), 0) AS Total
     
    FROM conteneur c
    WHERE YEAR(datedec)=:an && cdet=:cdet									
    RIGHT OUTER JOIN numsem m ON  DATE_FORMAT(datedec,"%U") = m.ns 
    GROUP BY YEAR(c.datedec), 
    DATE_FORMAT(datedec,"%U"),
    m.ns
    ORDER BY m.ns ASC ');
     
     
    try {
    // On envois la requète
    	$ann   	= trim(htmlspecialchars(stripslashes($_POST['an'])));
    	$cdet   =  trim(htmlspecialchars(stripslashes($_SESSION['cdet'])));
     
    	$resem->bindParam(':an',   $ann , PDO::PARAM_INT); 
    	$resem->bindParam(':cdet', $cdet , PDO::PARAM_STR); 
    	$resem->execute();
    	// On récupère en 1er toutes les données
    	$dataresem = $resem->fetchAll(PDO::FETCH_ASSOC);
    	// libèré la connexion du serveur
    	$resem->closeCursor();	
     
     
    }
    catch( Exception $e ){
     echo 'Erreur d\'affichage : ', $e->getMessage();
     }
    			/*----------------- fin affichage */
    ?>
    message d'erreur:
    Erreur d'affichage : SQLSTATE[42000]: Syntax error or access violation: 1064 You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'RIGHT OUTER JOIN numsem m ON DATE_FORMAT(datedec,"%U") = m.ns GROUP ' at line 13
    donc le problème se pose avec la clause WHERE. !!!

  2. #2
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut
    Eh Oui c'est la Forme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    // même requête avec
    RIGHT OUTER JOIN numsem m ON  DATE_FORMAT(datedec,"%U") = m.ns 
    WHERE (YEAR(c.datedec)=:an) && (c.cdet=:cdet)
    ............................
    sa marche très bien , là je me demande si la close WHERE est bien dans le bon endroit !!!!!!! dans mon cas elle est après la jointure non!!!

  3. #3
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Les jointures font partie des références de tables, donc doivent se trouver au niveau du FROM avant la clause WHERE.

    Donc oui, ton where est mal placé par rapport à ton outer join. ça devrait être :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT     
        m.ns,
        COALESCE((DATE_FORMAT(datedec,"%U")),0) AS NS,
        YEAR(c.datedec) AS Annee,
        COALESCE((sum(c.m) + sum(c.m1) + sum(c.m2) + sum(c.m3) + sum(c.m4) + sum(c.m5) + sum(c.m6) + sum(c.m7) + sum(c.m8)), 0) AS Total_M,
        COALESCE((sum(c.f) + sum(c.f1) + sum(c.f2) + sum(c.f3) + sum(c.f4) + sum(c.f5) + sum(c.f6) + sum(c.f7) + sum(c.f8)), 0) AS Total_F,
        COALESCE((sum(c.m) + sum(c.m1) + sum(c.m2) + sum(c.m3) + sum(c.m4) + sum(c.m5) + sum(c.m6) + sum(c.m7) + sum(c.m8) + sum(c.f) + sum(c.f1) + sum(c.f2) + sum(c.f3) + sum(c.f4) + sum(c.f5) + sum(c.f6) + sum(c.f7) + sum(c.f8)), 0) AS Total
    FROM 
        conteneur c 
        RIGHT OUTER JOIN numsem m ON  DATE_FORMAT(datedec,"%U") = m.ns 
    WHERE YEAR(datedec)=:an && cdet=:cdet
    GROUP BY YEAR(c.datedec), DATE_FORMAT(datedec,"%U"), m.ns
    ORDER BY m.ns ASC
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  4. #4
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut
    Salam ; donc ma deuxième résolution est bonne.
    si on essaye de voir le fonctionnement de la requête:
    l'optimiseur fait la sélection en appliquant les paramètres ensuite il passe a la jointure !
    ou deuxième cas de figure, il fait la jointure ensuite il fait la sélection selon les paramètres et là je crois que ça va répercuté sur la performance non!!!

  5. #5
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Je te conseille de lire ceci , qui devrait expliquer mieux que moi.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  6. #6
    Membre éprouvé Avatar de redoran
    Homme Profil pro
    Développeur-Amateur
    Inscrit en
    Juin 2010
    Messages
    1 346
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur-Amateur
    Secteur : Santé

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 346
    Points : 1 031
    Points
    1 031
    Par défaut
    Merci pour le lien

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 20/04/2015, 11h15
  2. Réponses: 6
    Dernier message: 29/07/2014, 13h13
  3. Réponses: 5
    Dernier message: 09/03/2012, 10h31
  4. PROBLEME DE JOINTURE ENTRE DEUX TABLE
    Par DarkMax dans le forum Langage SQL
    Réponses: 13
    Dernier message: 13/01/2005, 15h11
  5. Jointure entre deux tables et résultat
    Par Asdorve dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/06/2004, 14h50

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