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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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 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

  2. #2
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 418
    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 418
    Par défaut
    Il y a un point virgule en trop dans ta requête.

  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
    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...

  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
    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 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);
    }
    ?>

  6. #6
    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
    Je viens de réessayer et ça a marché ; je ne cherche pas à comprendre le problème hier soir...

+ 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