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 :

Débugger une requête compilée avec la méthode "execute" [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Avatar de FMaz
    Inscrit en
    Mars 2005
    Messages
    643
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 643
    Points : 640
    Points
    640
    Par défaut Débugger une requête compilée avec la méthode "execute"
    Bon, il m'arrive souvent de ne pas être trop certain des valeurs que je met dans mes requêtes. Avant, j'avais pour habitude de faire un echo $query, et de copier-coller ma requête dans PHPMyAdmin pour la débugger.

    Mais avec PDO, je dois manuellement replacer toutes les variables que je bind dans la requête, vu que je n'arrive pas à afficher pleinement la requête.

    En capturant une exception, j'arrive à avoir la partie en cause, mais sans plus.
    Et PDO traite parfois les champs un peu étrangement.

    Enfin bref, tout ceci pour vous dire que j'aimerais bien avoir la requête complète avec toutes les valeurs insérées à l'intérieure pour des fins de débuggage, mais je ne trouve aucune facon de faire ca.



    Exemple de ce que j'aimerais:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    $query = 'SELECT *'
    		. ' FROM ' . CONFIG_DB_PREFIX . 'shop_item'
    		. ' WHERE id=?'
    		. ' LIMIT ?, ?;';
    	$prep = $db->prepare($query);
    	$prep->bindValue(1, (int)$this->id);
    	$prep->bindValue(2, (int)$startFrom);
    	$prep->bindValue(3, (int)$lenght);
    	$prep->execute();
     
    echo $prep->query; //Cette ligne n'est pas possible/supportée.
    Qui afficherait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT * FROM tt_shop_item  WHERE id='1' LIMIT '1', '16';
    Ce qui m'aurais permis ne pas perdre 1h de temps à me demander pourquoi mon LIMIT plantait à cause d'un bug dans la facon dont PDO traite les intergers !

    Quelqu'un as-t'il une solution facile à implanter ?

  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
    Une réponse est deux messages plus bas dans le forum PDO :
    http://www.developpez.net/forums/d82...uete-preparee/

    Concernant ton problème de LIMIT, il ne s'agit pas d'un bug, Bindvalue prend en paramètre le type de données :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $prep->bindValue(2, (int)$startFrom, PDO::PARAM_INT);
    $prep->bindValue(3, (int)$length, PDO::PARAM_INT);
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre confirmé
    Avatar de FMaz
    Inscrit en
    Mars 2005
    Messages
    643
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 643
    Points : 640
    Points
    640
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Concernant ton problème de LIMIT, il ne s'agit pas d'un bug, Bindvalue prend en paramètre le type de données :
    Non non, il s'agit bien d'un bug:
    http://bugs.php.net/bug.php?id=44639
    ( initialement: http://bugs.php.net/bug.php?id=40740 )

    Merci pour le lien vers le lien, j'ai mis ca en bookmark. Malheureusement, c'est quand même un peu complexe, j'avais espoir d'un truc qui tienne en une seule ligne de code

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

Discussions similaires

  1. [MySQL] concaténer une requête sql avec condition
    Par maliak dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 10/02/2006, 12h01
  2. Une requête SQl avec concaténation
    Par Bobybx dans le forum Langage SQL
    Réponses: 2
    Dernier message: 19/01/2006, 10h18
  3. Déterminer une requête paramétrée avec LIKE
    Par priest69 dans le forum Access
    Réponses: 4
    Dernier message: 24/10/2005, 19h29

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