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 :

[Conception] Methode execute de PDO


Sujet :

PHP & Base de données

  1. #1
    Rédacteur
    Avatar de Yoshio
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    1 732
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 732
    Par défaut [Conception] Methode execute de PDO
    Bonjour,

    Comment tester si cette méthode retorune une erreur ou pas ?!

    Selon mes quelques test, try {} ... catch {} ne marche pas en cas d'erreur.

    La seul solution que j'ai trouver c'est de faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if (!$query = $sql->execute()) die('error');
    Mais est vraiement correcte ou y a t-il une autre solution ?!


    NB: je travaille avec des requêtes préparées

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    882
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 882
    Par défaut
    salut
    regarde les methodes errorcode() pour l'objet pdo et pdostatement
    normalement si execute ne fonctionne pas tu a une trace avec et test avec la constante PDO::ERR_NONE

    c'esr execute qui ne foctionne pas ou prepare???

    et regarde si tu est configurer pour lancer des exception
    essaye
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $query->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION )

  3. #3
    Rédacteur
    Avatar de Yoshio
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    1 732
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 732
    Par défaut
    Ah bah en fait je n'ai aucun problème avec !

    J'aimerais juste savoir comment gérer en cas d'erreurs.

    Je vais regadrer les methode que tu as mentionnées

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    882
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 882
    Par défaut
    avec un bloc try catch et tu attrape les PDOException puis les Exceptions

  5. #5
    Rédacteur
    Avatar de Yoshio
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    1 732
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 732
    Par défaut
    je n'arrive pas a comprendre pourquoi utiliser un try ... catch (je l'ai fait pour la connexion à la db mais je voit pas l'intéret pour une simple requete sql)

    Par contre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if ($error = $this->db->errorInfo()) die('error');
    me semble plus approprié non ?!

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    882
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2004
    Messages : 882
    Par défaut
    le die arrete ton script et tu ne peut traité l'erreur correctement, les exception te le permette
    par example tu pourrai logguer l'erreur et affiché une page d'erreur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    try{
    $this->db->execute();
    }catch(PDOException $pdoe){
    $erreur = new errorhandler();
    $erreur>add( $pdoe );
    $erreur->log();
    $erreur->redirect($pdoe->getCode());
    }

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

Discussions similaires

  1. objet Connection methode execute id insert
    Par totoche dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 13/09/2006, 16h01
  2. conception / methode
    Par CR_Gio dans le forum C++
    Réponses: 5
    Dernier message: 03/06/2006, 17h47
  3. conception / methode
    Par CR_Gio dans le forum C
    Réponses: 13
    Dernier message: 03/06/2006, 16h31
  4. [Concept]Methode "static"
    Par Regis.C dans le forum Général Java
    Réponses: 5
    Dernier message: 04/01/2005, 10h10
  5. [VB6] méthode Execute Protocole Ftp
    Par marion$ dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 27/04/2004, 15h43

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