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

PHP & Base de données Discussion :

UPDATE ne fonctionne pas dans mon code PHP [PDO]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2014
    Messages : 11
    Points : 8
    Points
    8
    Par défaut UPDATE ne fonctionne pas dans mon code PHP
    Bonjour, j'essaie de faire un site permettant d'automatiser des choix dans un clan sur un jeu auquel je joue.

    J'ai essayé pendant de nombreuses heures à faire fonctionner mon code mais malheureusement celui-ci me fait la tête. A l'instant je travail pour rentrer les données dans ma base MySQL néanmoins je ne parvient pas à le faire puisque la fonction SQL 'UPDATE' ne fait rien au niveau de cette base. Pour que vous puissiez mieux comprendre pourquoi je n'y arrive pas et peut être me donner une certaine marche à suivre je vous mets mon code ci-dessous :

    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
    <?php
     
    /* ---- CONNEXION BASE DE DONNEES ----*/
    try {
        $bdd = new PDO('mysql:host=localhost; dbname=wot_votelogo; charset=utf8', 'root', '');
    } catch (Exception $e) {
        die('Erreur : ' . $e->getMessage());
    }
     
     
    /*---- RECUPERATION DES INFORMATIONS ----*/
    $choix  = $_POST['logo'];
    $pseudo = $_POST['pseudo'];
     
     
    /*---- UPDATE BASE DE DONNEES ----*/
    if ($bdd->exec("SELECT pseudo_player FROM player_wot;") == $pseudo) {
        if ($bdd->exec("SELECT avote_player FROM votelogo_user WHERE pseudo_player = '$pseudo';") == 0) {
            $bdd->exec("UPDATE votelogo_user SET avote_player = 1, choix_player = '$choix' WHERE pseudo_player = '$pseudo';");
            header('Location: http://local.dev/index.php?send=ok');
        } else {
            header('Location: http://local.dev/index.php?send=none');
            break;
        }
    } else {
        header('Location: http://local.dev/');
        break;
    }
     
     
    ?>
    En espérant que vous sauriez m'aider.

    Cordialement, Daethe

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    as-tu vérifier ce que renvoie :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $bdd->exec("SELECT pseudo_player FROM player_wot;")
    (que tu tentes de comparer à $pseudo ) ?

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2014
    Messages : 11
    Points : 8
    Points
    8
    Par défaut
    Au sein de ma base, cela me renvoie l'intégralité de la colonne. Néanmoins il est vrai que la ligne me renvoie '0'.
    Mais l'autre chose c'est que le code me renvoie toujours dans ma barre d'adresse :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    header('Location: http://local.dev/TBVoteLogo/index.php?send=ok');
    Du coup c'est que cela fonctionne non ?

    Je pense que cette ligne devrait s'écrire finalement :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $bdd->exec("SELECT pseudo_player FROM player_wot WHERE pseudo_player = '$pseudo';");
    J'espère ne pas me tromper, mais je pense que vous êtes une personne possédant beaucoup de connaissance.
    Si j'ai faites d'autre bêtise dans ces requêtes vous pourriez me dire.

    Cordialement

  4. #4
    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 pense surtout que tu ne risques pas d'obtenir de données vu que :
    PDO::exec() ne retourne pas de résultat pour une requête SELECT.
    PHP: PDO::exec

    Mais effectivement, plutôt que récupérer toutes les lignes de ta table et les comparer ensuite, il vaut mieux faire une recherche et regarder si il y a un résultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $sth = $bdd->prepare("SELECT pseudo_player FROM player_wot WHERE pseudo_player = :pseudo");
    $sth->execute(array(':pseudo' => $pseudo));
    if( $row= $sth->fetch()) {
    	// pseudo trouvé en base
    }

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2014
    Messages : 11
    Points : 8
    Points
    8
    Par défaut
    Par conséquent en faisant cela, si l'utilisateur est trouvé j'enchaîne sur le reste du code en faisant à nouveau la partie que vous m'avez donné pour savoir si celui-ci a déjà voté ?

    Les données booléenne rentre dans ce même cas de figure ?

    (Désolé de mon manque de connaissance et de recherche évident.)

  6. #6
    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
    Tu enchaines effectivement sur la suite du traitement, en adaptant ton code existant pour qu'il fonctionne de la même façon.

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

Discussions similaires

  1. Un regex qui fonctionne sur les testeurs en ligne, mais pas dans mon code
    Par billybobbonnet dans le forum Développement Windows
    Réponses: 4
    Dernier message: 28/01/2015, 17h20
  2. fonction explode() ne fonctionne pas dans mon code
    Par Invité dans le forum Langage
    Réponses: 12
    Dernier message: 08/02/2013, 10h34
  3. Erreur dans mon code php que j'arrive à voir
    Par babouba dans le forum Langage
    Réponses: 2
    Dernier message: 19/03/2007, 16h48
  4. Réponses: 6
    Dernier message: 19/07/2006, 13h48
  5. Erreur dans mon code PHP
    Par jack_1981 dans le forum Langage
    Réponses: 6
    Dernier message: 12/05/2006, 10h01

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