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 :

prob. d' incrémentation /mysql UPDATE


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 68
    Par défaut prob. d' incrémentation /mysql UPDATE
    Mon code
    <?
    include("config.php");

    mysql_connect("localhost", $user_ftp, $password_ftp);
    mysql_select_db($bdd);
    $replay_a_dl=$_POST['replay'];
    $reponse = (mysql_query('SELECT * FROM `replays` '));
    $donnees = mysql_fetch_array($reponse);
    $dl=$donnees['nbr_dl'];
    $dl++;
    mysql_query('UPDATE replays SET nbr_dl= '.$dl. 'WHERE nom_replay='.$replay_a_dl); // ligne 12
    echo" : cette replay à été téléchargée ".$dl." fois";
    echo"<meta http-equiv=\"refresh\" content=\"nb_seconde;url=/monsiteperso/replays/".$replay_a_dl.".rec\">";

    ?>

    le problème : Cela ouvre la page de téléchargements, cela lis le nombre de fois inscrit dans la bdd que le fichier à été téléchargé, l'incrémentation dans la page fonctionne mais mon UPDATE ne fonctionne pas. Mon erreur?

  2. #2
    Expert confirmé Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Par défaut
    Ton erreur est dit par mysql =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    mysql_query('UPDATE replays SET nbr_dl= '.$dl. 'WHERE nom_replay ='.$replay_a_dl) or die (mysql_error());
                                                                                       ^^^^^^^^^^^^^^^^^^^

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 68
    Par défaut
    l'erreur : parse error, unexpected T_STRING in /home/pankench/public_html/monsiteperso/dl_replay.php on line 12

    cela vient de quoi ^^?

  4. #4
    Membre émérite
    Avatar de ozzmax
    Inscrit en
    Novembre 2005
    Messages
    977
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Novembre 2005
    Messages : 977
    Par défaut Re: prob. d' incrémentation /mysql UPDATE
    Salut
    juste pour voir c'est peut-etre un probleme de concetennation


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $strScript = "UPDATE replays SET nbr_dl = '$dl' WHERE  nom_replay = '$replay_a_dl';";
    mysql_query($strScript);

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 68
    Par défaut
    aucun changement

  6. #6
    Membre émérite
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    1 012
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 1 012
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query("UPDATE replays SET nbr_dl = '$dl' WHERE  nom_replay = '$replay_a_dl'");

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 68
    Par défaut
    l'update ne fonctionne tjrs pas...

  8. #8
    Membre émérite
    Avatar de ozzmax
    Inscrit en
    Novembre 2005
    Messages
    977
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Novembre 2005
    Messages : 977
    Par défaut
    Ouin c'est embettant
    est ce que tu as testé toutes les variables php que tu mets dans ta requete...

    $replay_a_dl elle est p-e vide
    essaie
    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
     
    if(isset($_POST['replay'])){
     mysql_connect("localhost", $user_ftp, $password_ftp); 
     mysql_select_db($bdd); 
     $replay_a_dl=$_POST['replay']; 
     $reponse = (mysql_query('SELECT * FROM `replays` ')); 
     $donnees = mysql_fetch_array($reponse); 
     $dl=$donnees['nbr_dl']; 
     $dl++; 
     mysql_query('UPDATE replays SET nbr_dl= '.$dl. 'WHERE nom_replay='.$replay_a_dl); // ligne 12 
     echo" : cette replay à été téléchargée ".$dl." fois"; 
     echo"<meta http-equiv=\"refresh\" content=\"nb_seconde;url=/monsiteperso/replays/".$replay_a_dl.".rec\">";
    }
    else{
     echo"pas de post";
    }
    Car la vraiment je ne vois pas...

  9. #9
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 68
    Par défaut
    $ replay a dl fonctionne vu que l'echo aussi, l'incrémentation aussi vu qui lit 0 dans la bdd et qu''il met 1 en echo

  10. #10
    Membre confirmé Avatar de Avatar
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Juillet 2005
    Messages
    137
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 137
    Par défaut
    b'soir

    tu as essayé de faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo 'UPDATE replays SET nbr_dl= '.$dl. 'WHERE nom_replay='.$replay_a_dl;
    et de tester le résultat dans phpmyadmin?

  11. #11
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 68
    Par défaut
    super j'ai trouvé une partie de l'erreur si je met :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query("UPDATE replays SET nbr_dl = \"27\" WHERE nom_replay = \"".$replay_a_dl."\"");
    cela m'update a 27 la valeur

    par contre si je met :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query("UPDATE replays SET nbr_dl = \"".$dl."\" WHERE nom_replay = \"".$replay_a_dl."\"");
    cela ne fait rien

  12. #12
    Membre confirmé
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Avril 2005
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Directeur des systèmes d'information
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2005
    Messages : 29
    Par défaut
    mysql_query('UPDATE replays SET nbr_dl= '.$dl. 'WHERE nom_replay='.$replay_a_dl); // ligne 12

    déja il faut corrige
    mysql_query('UPDATE replays SET nbr_dl= `'.$dl. '` WHERE nom_replay='.$replay_a_dl);

  13. #13
    Membre Expert
    Avatar de ska_root
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    1 203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Août 2005
    Messages : 1 203
    Par défaut
    N'oubliez pas de commenter vos codes, c'est plus facile pour tout le monde ;-)

    N'oubliez pas de vous servir des retours de mysql pour débuguer plus facilement

    et pour finir, n'oubliez pas que le trop plein de quote rends le code indigérable...

    essaies 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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
     
    if(isset($_POST['replay'])) {
     
       // connexion
       mysql_connect("localhost", $user_ftp, $password_ftp) or die (mysql_error()); 
       mysql_select_db($bdd) or die (mysql_error()); 
     
       // recuperation de la superglobale
       // chaine vide si pas définie
       $replay_a_dl=(!isset($_POST['replay']))?(''):($_POST['replay']);
     
       // requete d'incrementation
       $res = mysql_query("UPDATE replays SET nbr_dl=nbr_dl + 1 WHERE nom_replay='$replay_a_dl'");
       if(!$res) die (mysql_error());
     
       // requete de projection
       $res = mysql_query("SELECT nbr_dl FROM replays WHERE nom_replay='$replay_a_dl'");
       if(!$res) die (mysql_error());
       $row = mysql_fetch_row($res);
       $nb = $row[0];
     
       // affichage de la reponse
       echo " : cette replay a été télechargée $nb fois"; 
       echo "<meta http-equiv=\"refresh\" content=\"nb_seconde;url=/monsiteperso/replays/{$replay_a_dl}.rec\">";
    }
    else{
     echo"pas de post";
    }

  14. #14
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    68
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 68
    Par défaut
    c'est magnifique cela fonctionne,merci , même si je n'ai pas comprit certaines subtilités de ton code comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (!isset($_POST['replay']))?(''):($_POST['replay'])
    [/code]

  15. #15
    Membre Expert
    Avatar de ska_root
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    1 203
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Service public

    Informations forums :
    Inscription : Août 2005
    Messages : 1 203
    Par défaut
    Citation Envoyé par K4trix
    c'est magnifique cela fonctionne,merci , même si je n'ai pas comprit certaines subtilités de ton code comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (!isset($_POST['replay']))?(''):($_POST['replay'])
    [/code]
    $variable=(condition)?(a faire)sinon);
    $variable=(si pas défini)?(une chaine vide)sinon la valeur de la superglobale);
    ;-)

  16. #16
    Membre émérite
    Avatar de ozzmax
    Inscrit en
    Novembre 2005
    Messages
    977
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Novembre 2005
    Messages : 977
    Par défaut
    c'est une autre maniere de faire des conditions ska_root que je ne connaissais pas qui sauve de la place en fin de compte
    je vais prendre en note merci

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

Discussions similaires

  1. auto-incrément Mysql sur Access
    Par maxireus dans le forum Access
    Réponses: 8
    Dernier message: 14/03/2008, 00h26
  2. Réponses: 1
    Dernier message: 26/04/2006, 21h44
  3. [MySQL] update a partir du resultat d'un select
    Par brice01 dans le forum Langage SQL
    Réponses: 10
    Dernier message: 05/04/2006, 22h44
  4. auto-incrément Mysql sur Access
    Par maxireus dans le forum Access
    Réponses: 4
    Dernier message: 07/03/2006, 00h35
  5. auto-incrément Mysql sur Access
    Par maxireus dans le forum SQL Procédural
    Réponses: 6
    Dernier message: 06/03/2006, 21h20

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