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 :

Aidez-moi à corriger les erreurs dans mon Code PHP-PDO


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2013
    Messages
    452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2013
    Messages : 452
    Points : 66
    Points
    66
    Par défaut Aidez-moi à corriger les erreurs dans mon Code PHP-PDO
    Bonjour.

    J'ai essayé de modifier ce vieux Code basé sur MYSQL QUERY (obsolète) ci-après:

    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
    function Withdraw($pin,$phone,$accNo,$amt){
     
    $sql= "SELECT * FROM  accountDetails where mobile=$phone";
    $result = mysql_query($sql);
    $Type = "withdraw";
    $insertbal = "insert into Activities(accountNo,pin,Amt,activityType) values ('$accNo','$pin',$amt *-1,'$Type')";
     
    $sqlupdate = "UPDATE accountDetails set balance = balance-$amt where mobile='$phone'";
    if(mysql_query($insertbal)){
           mysql_query($sqlupdate);
     
     return "You have withdrawn. ".$amt." from your account";
     }
     else
        {
            return "Sorry, Cant withdraw";
     
     }
    }
    CI-DESSOUS CE QUE J'AI MODIFIER En MYSQL PDO:

    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
    function Withdraw($pin,$phone,$accNo,$amt){
     
    global $bdd;
     
    $sql= "SELECT * FROM  accountDetails where mobile=:phone";
    $stmtSelect = $bdd->prepare($sql);
    $result = $stmtSelect->execute([':phone' => $phone]); 
    $Type = "withdraw";
     
    $stmtInsert = "INSERT INTO Activities(accountNo,pin,Amt,activityType) values (':accNo',':pin',:amt *-1,':Type')";
    $stmtInserto = $bdd->prepare($stmtInsert);
    $insertbal = $stmtInserto->execute([
    	':phone' => $phone,
    	':pin' => $phone,
    	':amt *-1' => $amt *-1,
    	':Type' => $Type
    ]);
     
    $sqlupdate = "UPDATE accountDetails SET balance = balance-:amt WHERE mobile=:phone";
    $stmtUpdate = $bdd->prepare($sqlupdate);
     
    if($insertbal){
           $sqlupdate = $stmtUpdate->execute([
    			':amt' => $amt,
    			':phone' => $phone
    		]); 
     
     return "You have withdrawn. ".$amt." from your account";
     }
     else
    	{
    		return "Sorry, Cant withdraw";
     
     }
    }
    Aidez-moi à corriger mon Code ci-après surtout au niveau des lignes 10 (je me demande si :amt *-1 de la VALUES de la requête d'insertion ???) et 19 (et là si :amt qui devait normalement être soustraire de la Balance lors du UPDATE est correcte ???).

    Merci d'avance.

  2. #2
    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 n'as pas besoin de mettre des quotes autour des marqueurs.
    Concernant ton paramètre avec le *-1, il faut que tu décides si tu le fais dans la requête ou dans la valeur, sinon tu vas le faire deux fois. Personnellement je recommanderai plutôt de le faire dans la variable.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    $stmtInsert = "INSERT INTO Activities(accountNo,pin,Amt,activityType) values (:accNo, :pin, :amt, :Type)";
    $stmtInserto = $bdd->prepare($stmtInsert);
    $insertbal = $stmtInserto->execute([
    	':phone' => $phone,
    	':pin' => $phone,
    	':amt' => $amt *-1,
    	':Type' => $Type
    ]);
    Pour l'update, ça m'a l'air ok. SI ça ne fonctionne pas, tu peux essayer d'utiliser les fonctions bindParam ou bindValue pour préciser le type.

  3. #3
    Membre du Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2013
    Messages
    452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Conseil

    Informations forums :
    Inscription : Octobre 2013
    Messages : 452
    Points : 66
    Points
    66
    Par défaut
    Merci beaucoup pour m'avoir éclairé.

Discussions similaires

  1. Comment détecter les erreurs dans un code php sans faire l'exécution
    Par hamrouni wassim dans le forum Bibliothèques & Frameworks
    Réponses: 0
    Dernier message: 24/08/2015, 23h01
  2. erreur dans mon code PHP
    Par msi79 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 07/10/2011, 14h47
  3. Réponses: 3
    Dernier message: 21/05/2008, 16h37
  4. Erreur dans mon code php que j'arrive à voir
    Par babouba dans le forum Langage
    Réponses: 2
    Dernier message: 19/03/2007, 16h48
  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