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 :

Insérer un lien en php avec PDO [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2012
    Messages : 27
    Points : 22
    Points
    22
    Par défaut Insérer un lien en php avec PDO
    Bonjour,

    Je débute à peine en programmation web (je suis en stage pour mon bts où je dois créer un site), ne vous moquez pas de mon petit niveau s'il vous plait ^^".
    Pour ce site j'ai répertorié les images sur ma base de données de la manière suivante:
    PHOTOS(id_photo, nom_photo, lien_photo) renvoyant respectivement (int, string, string)

    Mon problème:
    J'ai suivi les tutos sur le net, cependant lorsque j'essaye d'afficher une image pour vérifier si ça fonctionne, l'erreur suivante s'affiche:
    Fatal error: Cannot use object of type PDOStatement as array in C:\wamp\www\stage\index.php on line 52

    Si j'ai bien compris PDO ne me renvoie pas mes variables comme je le voudrais, par exemple elle ne me renvoie pas un string pour le lien (enfin je crois O.o).

    Mon code:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     <!--Connexion à la bdd -->
     
      <?php
    try
    {
    	$pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    	$bdd = new PDO('mysql:host=localhost;dbname=nafetisio', 'root', '', $pdo_options);
    }
    catch (Exception $e)
    {
            die('Erreur : ' . $e->getMessage());
    }
    ?>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <div id="image">
                <?php
      $reponse = $bdd->query('SELECT Lien_photo FROM Photos WHERE Id_photo = 1');
    echo '<img src="' . $reponse["lien_photo"] . '"/>';
      ?>
    	</div>
    Merci de votre attention.

  2. #2
    Expert éminent
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Points : 7 762
    Points
    7 762
    Par défaut
    ne vous moquez pas de mon petit niveau s'il vous plait ^^".
    On est pas tous cruel à ce point, moi si

    Il y a une différence majeur entre PDO et mysql_* et mysqli_*. PDO fonctionne intégralement en objet, il ne renvoie pas de ressources et encore moins des tableaux directement exploitables.

    Une fois la requête exécutée avec succès, PDO renvoie une instance de PDOStatement, il faut maintenant "aller chercher" les données avec fetch, fetchColumn, fetchAll ou tout simplement en traversant les résultats avec foreach (sans doute le plus simple). Tout est expliqué dans le manuel de PDOStatement.

    Exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $statement = $pdo->query('...');
    if (!$statement) {
      // erreur dans la requête
    }
    else {
      foreach ($statement as $line) {
         var_dump($line);
      }
    }

  3. #3
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2012
    Messages : 27
    Points : 22
    Points
    22
    Par défaut
    Merci beaucoup!

    Je teste et je vous dis si ça fonctionne. =)

  4. #4
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Mai 2012
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2012
    Messages : 27
    Points : 22
    Points
    22
    Par défaut
    J'édite j'ai trouvé où j'avais un soucis! j'avais oublié une ligne -.-
    Du coup j'ai bien un retour de mon chemin mais j'arrive pas à le caser pour afficher la photo je cherche!

    Edit: problem solved, merci en tout cas !

    Si quelqu'un cherche :

    <div id="image">
    <?php
    $recup = $bdd->prepare("SELECT lien_photo FROM photos WHERE id_photo=1");
    $recup->execute();
    $result = $recup->fetch(PDO::FETCH_ASSOC);
    $palapoum = (string)$result["lien_photo"];
    echo '<img src="' .$palapoum. '" height="100%" widht="100%" />';
    ?>
    J'espère n'avoir pas trop floodé. Encore merci!

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

Discussions similaires

  1. PHP avec PDO ?
    Par CrazyCat dans le forum Solaris
    Réponses: 1
    Dernier message: 21/04/2012, 10h36
  2. les liens et php avec les "include"
    Par pp_le_moko dans le forum Langage
    Réponses: 4
    Dernier message: 20/12/2010, 17h38
  3. Lien en PHP avec htaccess
    Par orphen dans le forum Langage
    Réponses: 5
    Dernier message: 30/08/2008, 15h32
  4. [html][CSS]insérer un lien avec css ?
    Par Phenomenium dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 16/01/2006, 20h14

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