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 :

Probleme dans la requête update [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Juillet 2015
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2015
    Messages : 5
    Points : 4
    Points
    4
    Par défaut Probleme dans la requête update
    salut tous
    je suis débutante (take me easy) alors je suis entrain de faire une requête UPDATE avec l'utilisation d' un resulta du SELect au debut jai utilisé une seule requete et ca na pas marché il faut faire un tabl temporaire (car on peut pas modifier la meme ligne dont on selecte ) dou je l'ai composé en 2 sous requête Object of class PDOStatement could not be converted to string
    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
    46
    47
    48
    49
    50
    51
    52
    53
     
     
     
     
     
     
    <?php
    if (isset($_POST['confirm'] ))
    {
        $nomMentee= $_POST['nameMentee']  ;
        $nomMentor = $_POST['nameMentor'] ; 
     
        if ((  $nomMentee) && (  $nomMentor ) )
        {
            include_once 'connexion.php'  ;   
     
            try {
                try {
                    $sql1='select id from user  where  nomprenom= "'.$nomMentor.'" ' ;
     
                    $stmt1 = $databaseConnection->query($sql1);
     
                   }
                catch(PDOException $e){
                    echo $sql . "<br>" . $e->getMessage();
                }
     
                $sql = 'UPDATE user set Mentor = '.$stmt1.'   // quest ce que je mets ici cest un entiier pas string 
    
    
                       where nomprenom = "'.$nomMentee .'" ' ;  
     
     
     
                // Prepare statement
                $stmt = $databaseConnection->prepare($sql);
     
                // execute the query
                $stmt->execute();
     
                // echo a message to say the UPDATE succeeded
                echo $stmt->rowCount() . " records UPDATED successfully";
            }
            catch(PDOException $e){
                    echo $sql . "<br>" . $e->getMessage(); }
     
     
            $databaseConnection = null;
        }
    }
    //header ('Location : tablo.php') ;
     
    ?>
    merci de m'aider i need it reaaly

  2. #2
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    bonjour,
    Bonjour,

    1) Inspire-toi du code de l'example 2 sur cette page, pour faire des requêtes préparées

    http://php.net/manual/fr/pdo.prepare.php

    2) N'imbrique pas tes blocs try and catch... c'est inutile. L'idée de cette syntaxe, c'est que, quelle que soit l'erreur, il te la choppe au passage et te l'affiche... Donc un seul bloc, pas de souci.

    3) dis-nous ce que tu veux faire "en français" avec mentor et mentee... là, je n'ai pas compris, mais il y aura probablement moyen de faire un seul mouvement en SQL.

    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
    if (isset($_POST['confirm'] ))
    {
        $nomMentee= $_POST['nameMentee']  ;
        $nomMentor = $_POST['nameMentor'] ; 
     
        if ((  $nomMentee) && (  $nomMentor ) )
        {
            include_once 'connexion.php'  ;   
     
            try {
    			//là pour moi, il manque une ligne du genre
    			$databaseConnection=new PDO('blablabla');
     
    			$sql1='select id from user  where  nomprenom=?' ;
    			$stmt=$databaseConnection->prepare($sql1);
    			$stmt>execute(array($nomMentor));
    		   //si tu es sûre qu'il n'y en a qu'un
    			$row=$stmt->fetch(PDO::FETCH_ASSOC);		   
    			echo '<pre>';
    			print_r($row);
    			echo '</pre>';//là, je ne sais pas ce que tu veux en faire, de cet id récupéré ?
     
     
                $sql = 'UPDATE user set Mentor =?  
                       where nomprenom =?';  
                $stmt = $databaseConnection->prepare($sql);
               	$stmt>execute(array($valeur1,$valeur2));//rien compris à ce que tu veux faire, mais tu remplace le premier ? par valeur1, et le second ? par valeur2
     
                echo $stmt->rowCount() . " records UPDATED successfully";
            }
            catch(PDOException $e){
                    echo $sql . "<br>" . $e->getMessage(); }
     
     
            $databaseConnection = null;
        }
    }
    //header ('Location : tablo.php') ;
     
    ?>
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Juillet 2015
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2015
    Messages : 5
    Points : 4
    Points
    4
    Par défaut Solution,
    Bonjour Merci pour votre réponse alors j'ai trouvé une solution avant jai utilisé une seule requette mais jai recu une erreur quil faut utilser un tabl temporiare puisk on peut modifier une table ou jai fait un SELECT

    Jai encore bcp de soucis et je sens que mon code nest pas du tt organisé
    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
    46
    47
    48
    49
    50
     
    <?php
    if (isset($_POST['confirm'] ))
    {
        $nomMentee= $_POST['nameMentee']  ;
        $nomMentor = $_POST['nameMentor'] ; 
     
        if ((  $nomMentee) && (  $nomMentor ) )
        {
            include_once 'connexion.php'  ;   
     
            try {
                try {
                    $sql1='select id from user  where  nomprenom= "'.$nomMentor.'" ' ;
     
                    $stmt1 = $databaseConnection->query($sql1);
                    $result = $stmt1->setFetchMode(PDO::FETCH_NUM);
                    $row = $stmt1->fetch() ;
     
                   }
                catch(PDOException $e){
                    echo $sql . "<br>" . $e->getMessage();
                }
     
                $sql = 'UPDATE user set Mentor = '.$row[0].'
    
    
                       where nomprenom = "'.$nomMentee .'" ' ;  
     
     
     
                // Prepare statement
                $stmt = $databaseConnection->prepare($sql);
     
                // execute the query
                $stmt->execute();
     
                // echo a message to say the UPDATE succeeded
                echo $stmt->rowCount() . " records UPDATED successfully";
            }
            catch(PDOException $e){
                    echo $sql . "<br>" . $e->getMessage(); }
     
     
            $databaseConnection = null;
        }
    }
    header ('Location : tablo.php') ;
     
    ?>

  4. #4
    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
    Ecris tes codes plus simplement :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <?php
    if (isset($_POST['confirm']) && !empty($_POST['nameMentee']) && !empty($_POST['nameMentor'])) {
     
            require_once 'connexion.php';
     
            $sth = $databaseConnection->prepare('SELECT id FROM user WHERE  nomprenom= :mentor');
            $sth->execute(array(':mentor'=>$_POST['nameMentor']));
            $mentor_id = $sth->fetchColumn();
     
            $sth = $databaseConnection->prepare('UPDATE user SET Mentor = :mentor_id WHERE  nomprenom= :eleve');
            $sth->execute(array(':mentor_id'=>$mentor_id, ':eleve'=>$_POST['nameMentee']));
    }
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Candidat au Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Juillet 2015
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2015
    Messages : 5
    Points : 4
    Points
    4
    Par défaut
    Merci =) c'est gentil de votre part

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

Discussions similaires

  1. probleme dans la requête update c#
    Par x2005man dans le forum C#
    Réponses: 11
    Dernier message: 19/03/2015, 14h26
  2. [MySQL] Problème d'apostrophes dans ma requête Update
    Par method_man dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 24/04/2007, 16h06
  3. [MySQL] nombre d'enregistrements maj dans une requête update
    Par erwan.bodere dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 15/06/2006, 16h11
  4. Inclure un SELECT dans une requète Update
    Par carolinebelle dans le forum Langage SQL
    Réponses: 2
    Dernier message: 19/07/2005, 14h19
  5. petit probleme dans une requte POSTGRE SQL
    Par ghis le fou dans le forum Requêtes
    Réponses: 5
    Dernier message: 08/09/2003, 13h51

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