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érer données en objet avec PDO [PDO]


Sujet :

PHP & Base de données

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut récupérer données en objet avec PDO
    Bonsoir,

    je comprends pas pourquoi ce code marche pas (veut dire ici "n'affiche rien" ; la connexion marche bien puisque j'utilise avec succès le code ailleurs...)

    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
     
    session_start();	
     
    $PARAM_hote='---'; // le chemin vers le serveur
    $PARAM_nom_bd='---'; // le nom de votre base de données
    $PARAM_utilisateur='---'; // nom d'utilisateur pour se connecter
    $PARAM_mot_passe='---'; // mot de passe de l'utilisateur pour se connecter
    $connexion = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe);	
     
    $_SESSION['patient_sel']=$_POST['nom_patient'];
    //echo "nom patient=".$_SESSION['patient_sel']."<br/>";
     
    $sql="SELECT ausc_vasc,non_fait from `medecin` WHERE id_patient=?;";
     
    $prep = $connexion->prepare($sql);
     
    $prep->bindValue(1, $_SESSION['patient_sel'], PDO::PARAM_STR);	
     
    //Compiler et exécuter la requête
    $prep->execute();
     
    $prep->setFetchMode(PDO::FETCH_OBJ); // on dit qu'on veut que le résultat soit récupérable sous forme d'objet
    while( $ligne = $prep->fetch() ) 
    	{
    		echo 'ausc_vasc : '.$ligne->ausc_vasc.'<br />'; 
    		echo 'non_fait : '.$ligne->non_fait.'<br />'; 
    	}
     
    $prep->closeCursor(); // on ferme le curseur des résultats

    et la table `medecin` a cette structure :
    id_medecin mediumint(8) unsigned NO PRI auto_increment
    ausc_vasc varchar(15) YES
    non_fait tinyint(4) YES
    id_patient varchar(35) YES
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  2. #2
    Expert éminent sénior

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 380
    Points : 10 410
    Points
    10 410
    Par défaut
    Il y a un point virgule en trop dans ta requête.

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Merci, j'avais pas vu cette faute de frappe ; corrigée : $sql="SELECT ausc_vasc,non_fait from `medecin` WHERE id_patient=?"; mais toujours pas d'affichage...
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour,
    ce point virgule marque la fin de la requête.
    Il est tout à fait autorisé en SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql="SELECT ausc_vasc,non_fait from `medecin` WHERE id_patient=?;";
    Cela dit, tu as intérêt à utiliser cette notation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $sql="SELECT ausc_vasc, non_fait FROM `medecin` WHERE id_patient = :idpatient ;";
    $prep = $connexion->prepare($sql);
    $prep->bindValue( ':idpatient', $_SESSION['patient_sel'], PDO::PARAM_STR );
    Quand tu auras de nombreux paramètres à transmettre à la requête, ce sera bien plus clair que des =? =? =? et des 1, 2, 3...

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Merci pour ta remarque judicieuse que je ne m'étais pas encore faite vu que les requêtes préparées, c'est tout nouveau pour moi.

    Par contre, j'ai cherché à cerner davantage mon bug sachant ça devrait au moins afficher la partie purement textuelle...
    Le code que je montre est l'action d'un formulaire, mais maintenant, même si j'exécute le formulaire lui-même, page blanche...

    code du formulaire :
    Code html+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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    <?php
    session_start();
    try {
    	$PARAM_hote='---'; // le chemin vers le serveur
    	$PARAM_nom_bd='---'; // le nom de votre base de données
    	$PARAM_utilisateur='---'; // nom d'utilisateur pour se connecter
    	$PARAM_mot_passe='---'; // mot de passe de l'utilisateur pour se connecter
    	$connexion = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe);	
    	$sql = 'SELECT nom, prenom FROM `patient` ORDER BY nom';
    ?>
    <form method="post" action="<?php echo "action_".basename(__FILE__); ?>">
    <select name="nom_patient" onChange="this.parentNode.submit()">
    <?php
        echo '<option value="">Veuillez sélectionner le nom du patient</option>';
        foreach ($connexion->query($sql) as $row) {
    		$nom_patient=$row['nom'] ." ".$row['prenom'];
    		echo '<option value="'.$nom_patient.'">'.$nom_patient.'</option>';
    		}	
    ?>
    </select>
    </form>
    <?
    }
    catch(PDOException $e) {
        $msg = 'ERREUR PDO dans ' . $e->getFile() . ' L.' . $e->getLine() . ' : ' . $e->getMessage();
        die($msg);
    }
    ?>
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Je viens de réessayer et ça a marché ; je ne cherche pas à comprendre le problème hier soir...
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Malheureusement, ce soir, plus rien d'affiché ; entre temps, j'ai suivi les conseils de jreaux62 et de ABCIWEB, à savoir que je suis en local (Wamp) et que le code de la discussion #1 est devenu :
    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
        <?php 
    session_start();	
    try {
    	$sortie=0;	
     
    	$PARAM_hote='---'; // le chemin vers le serveur
    	$PARAM_nom_bd='---'; // le nom de votre base de données
    	$PARAM_utilisateur='---'; // nom d'utilisateur pour se connecter
    	$PARAM_mot_passe='---'; // mot de passe de l'utilisateur pour se connecter
    	$connexion = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe);		
     
    	$_SESSION['patient_sel']=$_POST['nom_patient'];
     
    	$sql="SELECT ausc_vasc,non_fait from `medecin` WHERE id_patient=:id_patient ;";
     
    	$prep = $connexion->prepare($sql);
     
    	$prep->bindValue(':id_patient', $_SESSION['patient_sel'], PDO::PARAM_STR );
     
    	//Compiler et exécuter la requête
    	$prep->execute();
     
     
    	$prep->setFetchMode(PDO::FETCH_OBJ); // on dit qu'on veut que le résultat soit récupérable sous forme d'objet
    	echo "ici1<br/>";
    	while( $ligne = $prep->fetch()) 
    	{
    			echo "ici2<br/>";
    			echo 'ausc_vasc : '.$ligne->ausc_vasc.'<br />';  $ausc_vasc=$ligne->ausc_vasc;
    			echo 'non_fait : '.$ligne->non_fait.'<br />'; $non_fait=$ligne->non_fait;
    	}
     
    	$prep->closeCursor(); // on ferme le curseur des résultats 
    ?>
    <a href="#" onclick=window.location('menu.html');>Continuer</a>
    <?php
    }
     
    catch(PDOException $e) {
        $msg = 'ERREUR PDO dans ' . $e->getFile() . ' L.' . $e->getLine() . ' : ' . $e->getMessage();
        die($msg);
    }
    ?>
    Les 2 mouchards ici1 et ici2 prouvent qu'on arrive au bord de la boucle mais qu'on ne rentre pas dedans (et comme je suis en local, display_error est à on, mais pas de message d'erreur.

    Comment faire ?
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Ca y est, c'est et on entrait pas dans la boucle car il n'y avait pas d'objet ! (Je m'étais trompé en écrivant la condition de la requête).
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  9. #9
    Expert éminent sénior

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 380
    Points : 10 410
    Points
    10 410
    Par défaut
    ça avance mais il reste encore quelques trucs à compléter.

    Par exemple si tu veux capturer quelque chose dans ton bloc catch encore faut-il dire à pdo de travailler en mode EXCEPTION (c'est le mode silence qui est le mode par défaut).
    On peut déclarer ça après ta connexion en faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $connexion->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    Sinon on peut le faire aussi au niveau de la connexion en envoyant un tableau d'options. Dans ces options tu pourrais mettre aussi le charset que tu utilises (je ne le vois nulle part dans ta connexion) et éventuellement le mode de retour que tu souhaites préférentiellement (fetch_objet, fetch_assoc).
    Ce qui pourrait donner par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $PARAM_hote='---'; // le chemin vers le serveur
    $PARAM_nom_bd='---'; // le nom de votre base de données
    $PARAM_utilisateur='---'; // nom d'utilisateur pour se connecter
    $PARAM_mot_passe='---'; // mot de passe de l'utilisateur pour se connecter
     
    $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    $pdo_options[PDO::ATTR_EMULATE_PREPARES] = false;//important sur les config récentes
    $pdo_options[PDO::ATTR_DEFAULT_FETCH_MODE] = PDO::FETCH_OBJ;//pour le mode objet
    $pdo_options[PDO::MYSQL_ATTR_INIT_COMMAND] = "SET NAMES utf8";//pour l'utf-8
     
    $connexion = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe, $pdo_options);
    Et cela t'éviterais aussi la ligne $prep->setFetchMode(PDO::FETCH_OBJ);

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Merci pour ton conseil ; je l'ai appliqué et dans la foulée, j'ai factorisé la connexion (comme ça, pas besoin de modifier partout) :

    Code php
    :
    Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    include_once("connect.php");
    try {
    	$sortie=0;	
     
    	$connexion=connect();
     
    ...

    et connect.php :
    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
    <?php
    function connect() {
    $PARAM_hote='localhost'; // le chemin vers le serveur
    $PARAM_nom_bd='test'; // le nom de votre base de données
    $PARAM_utilisateur='root'; // nom d'utilisateur pour se connecter
    $PARAM_mot_passe=''; // mot de passe de l'utilisateur pour se connecter
     
    $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    $pdo_options[PDO::ATTR_EMULATE_PREPARES] = false;//important sur les configs récentes
    $pdo_options[PDO::ATTR_DEFAULT_FETCH_MODE] = PDO::FETCH_OBJ;//pour le mode objet
    $pdo_options[PDO::MYSQL_ATTR_INIT_COMMAND] = "SET NAMES utf8";//pour l'utf-8
     
    $connexion = new PDO('mysql:host='.$PARAM_hote.';dbname='.$PARAM_nom_bd, $PARAM_utilisateur, $PARAM_mot_passe, $pdo_options);
    $connexion->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    return($connexion);	
    }
    ?>
    et j'ajoute que c'est vrai que c'est bien plus cool de développer en local...
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  11. #11
    Expert éminent sénior

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 380
    Points : 10 410
    Points
    10 410
    Par défaut
    On utilise setAttribute pour modifier un attribut de pdo par rapport aux valeurs précédemment définies (ou celles définies par défaut), mais si c'est pour indiquer une même valeur que celle déjà définie cela ne sert à rien.
    -> Cela ne sert à rien d'utiliser setAttribute après ta connexion pour indiquer à pdo de régler le mode d'erreur sur EXCEPTION puisque tu l'as déjà indiqué dans tes options.

    De la même façon je te disais plus haut que le fait de spécifier le mode de retour que tu souhaite dans les options de ta connexion t'éviterais d'avoir à écrire la ligne ->setFetchMode(PDO::FETCH_OBJ).

    On met nos réglages préférentiels dans les options justement pour ne pas avoir à les réécrire. Ensuite tu utiliseras éventuellement setAttribute, setFetchMode plus loin dans ton code si tu as des besoins différents en indiquant d'autres valeurs.

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 378
    Points : 5 731
    Points
    5 731
    Billets dans le blog
    1
    Par défaut
    Oui, exact, j'avais lu ton code trop vite...
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  13. #13
    Expert éminent sénior

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 380
    Points : 10 410
    Points
    10 410
    Par défaut
    J'ai édité mon précédent message pour le compléter pendant que tu postais ta dernière réponse... Enfin bon ça va dans le même sens. Bonne fin de journée.

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

Discussions similaires

  1. tutos base de donnée orientée objet avec Sql server
    Par marwa21 dans le forum MS SQL Server
    Réponses: 17
    Dernier message: 15/03/2011, 14h59
  2. Base de données relationnelle-objet avec MySQL
    Par tiger8 dans le forum Administration
    Réponses: 2
    Dernier message: 25/10/2010, 15h26
  3. [PDO] Insertion de données avec PDO
    Par pakkun dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 09/02/2008, 01h33
  4. [cURL] Récupérer données d'un site avec sessions
    Par Anified dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 24/10/2007, 16h57
  5. Réponses: 8
    Dernier message: 15/08/2007, 13h07

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