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 :

afficher le retour d'une requête sans fetch [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut afficher le retour d'une requête sans fetch
    Bonjour,

    je viens de démarrer l'étude d'un tuto (http://bpesquet.developpez.com/tutor...ture-mvc/#LI-B) et le code fourni me surprend. On affiche le résultat de l'exécution d'une requête select sans faire de fetch ; peut-on m'expliquer ?

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
                    $bdd = new PDO('mysql:host=localhost;dbname=monblog;charset=utf8',
                            'root', '');
                    $billets = $bdd->query('select BIL_ID as id, BIL_DATE as date,'
                            . ' BIL_TITRE as titre, BIL_CONTENU as contenu from T_BILLET'
                            . ' order by BIL_ID desc');
                    foreach ($billets as $billet):
                    //etc mais pas de fetch

  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
    Par défaut
    Premier exemple donné dans la documentation :
    http://php.net/manual/fr/pdo.query.php
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    OK, et pour être sûr de comprendre, l'exemple
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <?php
    function getFruit($conn) {
        $sql =  'SELECT name, color, calories FROM fruit ORDER BY name';
        foreach  ($conn->query($sql) as $row) {
            print $row['name'] . "\t";
            print  $row['color'] . "\t";
            print $row['calories'] . "\n";
      }
    }
    ?>
    écrit comme ça serait bien équivalent ?
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <?php
    function getFruit($conn) {
        $_res_req = $conn->query('SELECT name, color, calories FROM fruit ORDER BY name');
        foreach  ($_res_req as $res_req) {
            print $res_req['name'] . "\t";
            print  $res_req['color'] . "\t";
            print $res_req['calories'] . "\n";
      }
    }
    ?>

  4. #4
    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 : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    C'est bien ça.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Merci, ça me simplifie la vie car je venais d'entreprendre de faire le test, mais non seulement y a du travail (création d'une base et table MySQL), mais en plus, mon fichier de test était bugué (fatal error)...

    et de plus, n'y a t-il pas une différence de performance car dans le premier cas, on exécute N fois la requête alors que dans le deuxième, on ne l'exécute qu'une seule fois ?

  6. #6
    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
    Par défaut
    La requête n'est executée que la première fois, ensuite on déplace seulement le pointeur du tableau de résultat.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre Expert
    Avatar de Eric2a
    Homme Profil pro
    Technicien
    Inscrit en
    Septembre 2005
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Technicien

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 225
    Par défaut
    Salut,

    +1 Sabotage

    Je met quand-même un code pour illustrer (histoire de pas l'avoir saisi pour rien)

    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
    <?php
    function query($sql){
    	echo '<p>La fonction <em>query</em> ayant pour paramètre <em>'.$sql.'</em> (qui renvoie ici un tableau) est appelée une seule fois par <strong>foreach</strong></p>';
    	return array(
    		array('name'=>'Pomme',	'color'=>'rouge','calories'=>'?'),
    		array('name'=>'Banane',	'color'=>'jaune','calories'=>'?'),
    		array('name'=>'Poire',	'color'=>'jaune','calories'=>'?')
    	);
    }
     
    echo "<p>\n";
    foreach(query('SELECT name, color, calories FROM fruit ORDER BY name')as $row){
    	echo $row['name']."\t". $row['color']. "\t".$row['calories']. "\n";
    }
    echo "</p>\n";
    ?>

  8. #8
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Merci pour ta contribution.
    Ton code n'utilise pas MySQL ; cependant, j'ai essayé de le modifier un peu pour que ça l'utilise :
    Code php : 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
    <?php
    include "connect_mysqlfruit.php";
    function query($sql){
    	global $conn;
    	echo '<p>La fonction <em>query</em> ayant pour paramètre <em>'.$sql.'</em> (qui renvoie ici un tableau) est appelée une seule fois par <strong>foreach</strong></p>';
    	return($conn->query($sql));
    	/*return array(
    		array('name'=>'Pomme',	'color'=>'rouge','calories'=>'150'),
    		array('name'=>'Banane',	'color'=>'jaune','calories'=>'250'),
    		array('name'=>'Poire',	'color'=>'jaune','calories'=>'75')
    	);*/
    }
     
    echo "<p>\n";
    foreach(query('SELECT name, color, calories FROM fruit ORDER BY name') as $row){
    	echo $row['name']." ". $row['color']. " ".$row['calories']. "<br/>";
    }
    echo "</p>\n";
    ?>
    Il se trouve que la connexion était déjà codée, donc y avait pas trop de boulot, par contre, j'ai une erreur que j'aimerais bien comprendre :
    Fatal error: Cannot use object of type stdClass as array in C:\wamp\www\eis2\eis\fruit\querysansfetch2.php on line 16
    Et la connexion fonctionne (un var_dump($conn) le prouve)

    Et voici la table créée :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE TABLE IF NOT EXISTS `fruit` (
      `name` varchar(8) COLLATE utf8_bin NOT NULL,
      `color` varchar(8) COLLATE utf8_bin NOT NULL,
      `calories` varchar(8) COLLATE utf8_bin NOT NULL
    ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
     
    --
    -- Contenu de la table `fruit`
    --
     
    INSERT INTO `fruit` (`name`, `color`, `calories`) VALUES
    ('apple', 'red', '150'),
    ('banana', 'yellow', '250'),
    ('kiwi', 'brown', '75');

  9. #9
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Puis-je avoir une réponse en 2015 ?

  10. #10
    Membre Expert
    Avatar de Eric2a
    Homme Profil pro
    Technicien
    Inscrit en
    Septembre 2005
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Technicien

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 225
    Par défaut
    Laurent, l'exemple (sans base de données) était juste là pour montrer qu'un seul affichage (et donc un seul appel à la fonction) allait avoir lieu.

    Maintenant, je ne te serais d'aucun secours concernant la nouvelle erreur obtenue car je ne connais pas du tout PDO.

    Peut-être comme-ça ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    echo $row->name." ". $row->color. " ".$row->calories. "<br/>";

  11. #11
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Bien vu, vu qu'une de mes lignes pour la connexion est $pdo_options[PDO::ATTR_DEFAULT_FETCH_MODE] = PDO::FETCH_OBJ;//pour le mode objet.
    Et je suis surpris qu'un connaisseur n'utilise pas PDO ; tu fais comment pour gérer les bdd ?

  12. #12
    Membre Expert
    Avatar de Eric2a
    Homme Profil pro
    Technicien
    Inscrit en
    Septembre 2005
    Messages
    1 225
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Corse (Corse)

    Informations professionnelles :
    Activité : Technicien

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 225
    Par défaut
    Citation Envoyé par laurentSc
    tu fais comment pour gérer les bdd ?
    Je suis surtout un amateur et j'utilise mysqli... Mais c'est vrai que je devrais tester PDO car ça à l'air interessant.

  13. #13
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Moi, il y a quelques années, j'en étais encore aux fonctions mysqlxxx et je me suis mis à PDO ; jamais utilisé mysqli...

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 09/06/2006, 18h22
  2. RecordSource avec une requête sans résultat
    Par temar dans le forum Access
    Réponses: 4
    Dernier message: 23/05/2006, 18h13
  3. [MySQL] Retour d'une requête non voulue
    Par gregal dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 26/04/2006, 15h57
  4. Exécution d'une requête sans stocker les transactions
    Par Actarus69 dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 24/03/2006, 12h45
  5. [MySQL] Une liste déroulante affichant les données d'une requête SHOW par ordre alphabétique
    Par jack_1981 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 22/12/2005, 15h53

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