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 :

Récupération d'une requête mysqli préparée.


Sujet :

PHP & Base de données

  1. #1
    Membre éprouvé
    Avatar de Rakken
    Homme Profil pro
    Inscrit en
    Août 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 257
    Par défaut Récupération d'une requête mysqli préparée.
    Bonjour,

    C'est sans doute une question très idiote, mais... ca ne marche pas, j'ai relu la doc 15 fois, et je n'y comprend rien.
    Je suis entrain d'essayer mysqli et notamment les requêtes préparées.

    Voici deux tests, le premier (sans préparation) fonctionne nickel, mais avec le second, je n'ai pas de données.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    $this->db = new mysqli($this->host, $this->utilisateur, $this->password, $this->nomBase);
    (...)
     
    $sql = "select * from utilisateurs";
    	$ret = $this->db->query($sql);
    	Debug::printr($ret->fetch_assoc(), "RET=");
     
    	$stmt = $this->db->prepare($sql);
    	$stmt->execute();
    	Debug::printr($stmt->result_metadata()->fetch_assoc(), "PREPARE=");
    Le premier débug m'affiche mon premier enregistrement, ce qui me convient parfaitement :
    RET=
    Array
    (
    [id_utilisateur] => 1
    [login] => Rakken
    [password] => xxx
    (...) la liste des divers champs
    )
    Et le second :
    PREPARE= :
    Autant dire rien du tout. Pourquoi donc ?
    Il y a bien la solution d'utiliser les bind_results, mais je veux garder cette structure en tableau, car le tout est encapsulé dans une classe déjà faite.

    Bref, est-il possible de récupérer mes données de la même manière avec des requêtes préparées et non préparée ? Et si oui, qu'est-ce que j'ai mal fait ?

    Merci d'avance !

  2. #2
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 502
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 502
    Par défaut
    ceci fonctionne chez moi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Debug::printr($stmt->fetchAll(), "PREPARE=");

  3. #3
    Membre éprouvé
    Avatar de Rakken
    Homme Profil pro
    Inscrit en
    Août 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 257
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <?php
    	$mysqli = new mysqli("localhost", "root", "", "test");
    	$stmt = $mysqli->prepare("SELECT * FROM test");
    	$stmt->execute();
    	print_r($stmt->fetchAll());
    ?>
    Me donne :
    Fatal error: Call to undefined method mysqli_stmt::fetchAll()

  4. #4
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 502
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 502
    Par défaut
    Sorry, j'étais sur un PDO

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     $connect = new PDO('mysql:host=' . HOST . ';dbname=' . DBNAME, USER, PASSWORD);
     $connect->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
     $connect->exec("SET CHARACTER SET utf8");
     $res = $connect->prepare($sql);
     $res->execute();
     $data = $res->fetchAll();
     var_dump($data);

  5. #5
    Membre éprouvé
    Avatar de Rakken
    Homme Profil pro
    Inscrit en
    Août 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 257
    Par défaut
    Certes... Donc pas de solution en mysqli pur ?

  6. #6
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 502
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 502
    Par défaut
    si

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
        $mysqli = new mysqli(HOST, USER, PASSWORD, DBNAME);
    	$stmt = $mysqli->prepare("SELECT LastName FROM employees");
    	$stmt->execute();
            $stmt->bind_result($lastname);
            $stmt->fetch();
            return $lastname;

  7. #7
    Membre éprouvé
    Avatar de Rakken
    Homme Profil pro
    Inscrit en
    Août 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 257
    Par défaut
    Au risque de passer pour un râleur, en fait le truc à la base (cf la fin de mon premier post), c'est que j'aimerai récupérer le même objet quand je fais un prépare que quand je fais une query directe.

    L'idée, c'est que le tout est encapsulé une classe d'abstraction déjà codée qui fonctionnait avec mysql. En fait, le recordSet qui est retourné par un query, je l'ai inclus dans une classe genre MyRecordSet avec des méthodes du genre "suivant()" et mes résultats sont accessibles en faisant "champ['nomDuChamp']";

    Si je passe par le bind_result, soit je doit changer tous mes appels (non négociable ), soit je dois derrière m'arranger pour transformer ça en tableau, ce qui me semble idiot (surtout que dans l'appli, la majorité des selects sont des "select *").

    Par contre, dans les commentaires ici, j'ai lu ca :
    Citation Envoyé par php.net
    As a consequence, if you want to use to use fetch_row() with an executed prepared statement, first you'll have to get the result out of this statement with mysqli_store_result() or mysqli_use_result().
    Par contre, pas moyen d'en faire quoique ce soit...

Discussions similaires

  1. Récupération d'une requête SQL dans un ComboBox
    Par Hoopsy dans le forum Bases de données
    Réponses: 3
    Dernier message: 26/12/2010, 21h06
  2. Réponses: 8
    Dernier message: 16/06/2010, 12h32
  3. Récupération d'une requête en forme de chaine de caractères
    Par jarlaxe_789 dans le forum VBA Access
    Réponses: 2
    Dernier message: 06/05/2008, 18h08
  4. Réponses: 0
    Dernier message: 10/12/2007, 17h42
  5. Récupération d'une requête sous forme de tableau
    Par le--handballeur dans le forum iReport
    Réponses: 2
    Dernier message: 01/08/2006, 15h56

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