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 :

pas de modification base avec update pdo


Sujet :

PHP & Base de données

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    artisan
    Inscrit en
    Juin 2012
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : artisan
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2012
    Messages : 1
    Points : 1
    Points
    1
    Par défaut pas de modification base avec update pdo
    bonjour,
    ça ne marche pas rien ne change dans la base
    j'ai pas d'erreur est ce que cela vient du formulaire:

    PAGE FORMULAIRE
    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
    <?php
    try{
    $bdd = new PDO('mysql:host=localhost;dbname=arbin', 'root', '', array(PDO::MYSQL_ATTR_INIT_COMMAND =>'SET NAMES UTF8'));
    }catch(PDOException $e){
    echo "Une erreur est survenue lors de la connexion a la DB!.";
    echo "<br>".$e->getMessage();
    }
     
     
    $bdd->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
     
    ?>
    <form method="post" action="modif.php">
    <?php
    try
    {
    $sql = "SELECT * FROM fmail";
     
    $rep = $bdd->query($sql);
     
                   //comme ceci ?
     
                    $rep->setFetchMode(PDO::FETCH_ASSOC);
    	        while($req = $rep->fetch()){
     
    ?>
    <input type="hidden" name="id" value="<?php echo $req['id']; ?>" >
    Nom: <input type="text" name="nom" value="<?php echo $req['nom']; ?>"> <br>
    Mail: <input type="text" name="email" value="<?php echo $req['email']; ?>"><br>
    Numero: <input type="text" name="numero" value="<?php echo $req['numero']; ?>">
    <br>
     
    <br>
    <input type="submit" name="submit" value="Modifier"><br><hr>
     
    <?php
    }
     
    }catch(PDOException $e){
    echo "Un probleme avec la(es) requete(s)";
     
    }
     
    ?>
    </form>
    et donc PAGE MODIF:
    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
     
    <?php
     
    if(isset($_POST['id']))
    {
     
    try
    {
    //connection au serveur
    $db = new PDO('mysql:host=localhost;dbname=arbin', 'root', '', array(PDO::MYSQL_ATTR_INIT_COMMAND =>'SET NAMES UTF8'));
    }catch(PDOException $e){
    echo "Une erreur est survenue lors de la connexion a la DB!.";
    echo '<br>'.$e->getMessage();
    }
     
    $db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
     
     
    $sql = "UPDATE fmail SET nom='?', email='?', numero='?' WHERE id='?'";
    $req = $this->db->prepare($sql);
    $d = array($_POST['nom'], $_POST['email'],$_POST['numero'], $_POST['id']);
    $req->execute($d);
     
    }
     
    ?>

    merci encore pour votre aide

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    1 - dans la partie formulaire il te manque un "fetch" après ta "query" et a priori un "where" sur l'id dans ta requête sinon tu recupères toute la table

    2 - dans l'update, tu utilises $_POST['id'] mais il n'est pas présent dans le formulaire
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  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
    @jmch73 : ta modification a l'air correcte, mais je ne vois pas l'accolade fermante de la boucle.

    Au passage, dans ce genre de situation, ce serait une bonne idée de ne pas modifier ton post d'origine, mais plutôt poster une réponse avec ton nouveau code.
    (je précise pour le reste de la communauté que jmch73 a modifié le code de son premier post pour prendre en compte les remarques de sabotage, ce qui rend le processus un peu difficile à suivre)
    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]

Discussions similaires

  1. [MySQL] insertion d'info dans une base avec php pdo
    Par hémilie dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 13/02/2015, 11h34
  2. [MySQL-5.6] Ne peux pas utiliser une base avec un utilisateur crée
    Par cryo94 dans le forum Administration
    Réponses: 1
    Dernier message: 27/04/2013, 16h40
  3. [MySQL] Pas de modification base de données image
    Par ideal23 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 08/02/2012, 20h56
  4. [PostgreSQL] Afficher une image stockée dans la base avec PHP / PDO / PostgresSQL
    Par genamiga dans le forum PHP & Base de données
    Réponses: 18
    Dernier message: 16/02/2011, 13h02
  5. recréation base avec RMAN: modifs du initSID.ora
    Par lmargueritte dans le forum Recovery Manager
    Réponses: 4
    Dernier message: 15/06/2007, 14h30

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