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

Langage SQL Discussion :

Problème de jointure sur Select et Update


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 38
    Par défaut Problème de jointure sur Select et Update
    Bonjour à tous !

    J'ai un problème sur les jointures... j'ai tous essayé mais comme je ne m'y connais pas beaucoup en mysql, ca ne donne que des erreurs...

    Voici le code fonctionnel...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    		$result = $db->query('SELECT total FROM '.$db->prefix.'users LEFT JOIN topics ON users.username = topics.poster WHERE topics.id='.$id) or error('Erreur 01', __FILE__, __LINE__, $db->error());
    		$t_up = $db->result($result)+$_GET['t_up'];
    		$result = $db->query('SELECT username FROM '.$db->prefix.'users LEFT JOIN topics ON users.username = topics.poster WHERE topics.id='.$id) or error('Erreur 02', __FILE__, __LINE__, $db->error());
    		$username = $db->result($result);
     
    		$db->query('UPDATE '.$db->prefix.'users SET total=\''.$t_up.'\' WHERE username=\''.addslashes($username).'\'') or error('Erreur 1', __FILE__, __LINE__, $db->error());
    		$db->query('UPDATE '.$db->prefix.'topics SET t_check=\'1\' WHERE id='.$id) or error('Erreur 2', __FILE__, __LINE__, $db->error());
    Principe :
    Je souhaite ajouté la valeur "t_up" qui est numérique au champ "total" qui se trouve dans le profil de l'utilisateur.
    Une fois cette opération effectuée, je valide le topics, en modifiant "t_check" pour qu'aucune au personne de l'équipe ne surajoute les points...

    PS : Je vous demande de l'aide, car cette opération est effectué plusieurs dizaines de fois par jour... et par tranche de 4 requetes, ca en fait des hits !

    Merci pour l'aide que vous me donnerez

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    Et quelle est l'erreur ?

    Pourrais-tu commencer par nettoyer ton code pour ne faire apparaître que ce qui relève du SQL, et préciser les messages d'erreur retournés par le SGBD ?

    As-tu testé tes requêtes "à la main", en dehors de ton programme ?
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 38
    Par défaut
    Pour récupérer le total et le pseudo, je fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT total FROM users LEFT JOIN topics ON users.username = topics.poster WHERE topics.id=$id
    SELECT username FROM users LEFT JOIN topics ON users.username = topics.poster WHERE topics.id=$id
    Pour update le total et mettre la vérification, (où t_up est l'addition de la valeur actuelle de total et de ce qu'on souhaite ajouter)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    UPDATE users SET total='$t_up' WHERE username='$username'
    UPDATE topics SET t_check='1' WHERE id=$id
    J'ai essayé directement sur PhpMyAdmin, mais il me donne aussi des erreurs a cause des jointures...

    PS : Plus de précision : Je souhaiterai update dans users et topics qui ont respectivement en commun username et posteur, le champs total (dans users) et le champs t_check (dans topics)

  4. #4
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 134
    Par défaut
    J'ai essayé directement sur PhpMyAdmin, mais il me donne aussi des erreurs a cause des jointures...
    Mais encore...

    D'un point de vue SQL, je ne vois pas d'anomalie.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  5. #5
    Membre émérite
    Avatar de Ayana
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    901
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 901
    Par défaut
    Idem que al1_24.


    Par contre je trouve la syntaxe de ton update (en php) assez bizarre (au niveau des quotes). Est-ce sur le 1er update qu'il te sort une erreur ???
    Peux-tu nous donner ce qu'il te sort ?

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    38
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2004
    Messages : 38
    Par défaut
    Rebonjour

    Désolé du retard... mais Epreuves du bac oblige

    En fait il n'y a aucun problème sur ces quatres lignes...
    Mais je suis sur qu'on pourrait faire la même chose avec moins de requete... j'ai lu des tonnes de documentaion sur les JOIN, les LEFT JOIN, mais j'ai pas tout compris :S

    Est-ce que vous pourriez m'aidez à optimiser ces lignes ?

Discussions similaires

  1. Réponses: 39
    Dernier message: 21/12/2011, 20h01
  2. Problème de jointure sur plusieurs tables
    Par papouuu dans le forum Langage SQL
    Réponses: 1
    Dernier message: 25/01/2011, 14h02
  3. Réponses: 0
    Dernier message: 02/06/2009, 15h03
  4. Problème de jointure avec select
    Par khaoula_14_05 dans le forum SQL
    Réponses: 3
    Dernier message: 22/04/2008, 17h49
  5. Problème de Jointure sur 2 tables
    Par Andry dans le forum Langage SQL
    Réponses: 2
    Dernier message: 03/05/2006, 13h20

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