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 :

Fatal error: Uncaught Error: Cannot use object of type PDOStatement as array


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut Fatal error: Uncaught Error: Cannot use object of type PDOStatement as array
    Bonjour,

    Je me suis lancé sur un projet un peu compliqué sur mon site pour cela j'ai utilisé une architecture MVC en php avec un petit peu de POO. Mais voilà aujourd'hui je travaille sur mon site et je voudrais afficher le contenu "content" de ma BDD (un système d'article) quand l'on clique sur l'article qui correspond mais cela ne fonctionne pas et je ne vois pas trop d'où cela vient ...
    Le code :
    Page d'affichage de l'article :
    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
    17
    18
    19
    20
    21
    22
     
    <?php $titre = $_GET['title'] ?>
    <!-- NAV -->
    <?php ob_start(); ?>
    <a href="compte_sio.php?action=projet&amp;id_projet=<?= $_GET['id_projet'] ?>&amp;title=Cours" style="text-decoration: none; color: black"><i class="fas fa-long-arrow-alt-left"></i> Retour</a>       
    <?php
    while ($article = $postarticle->fetch()) {
    ?>
       <a href="compte_sio.php?action=post&amp;id_projet=<?= $_GET['id_projet']?>&amp;title=<?= $article['title'] ?>" style="text-decoration: none; color: black"><p class="navsio"><?= htmlspecialchars($article['title']) ?></p></a>
    <?php
    }
    $postarticle->closeCursor();
    ?>
    <?php $nav = ob_get_clean(); ?>
    <!-- CONTENU -->
    <?php 
    	ob_start(); 
    	echo $articleview['content'];
    	$content = ob_get_clean();
    ?>
     
    <?php require('template.php'); ?>
    Frontend
    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
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
     
    <?php
     
    require_once('class.php');
     
    function getlangage(){
    	$lang = new file();
    	$post = $lang->getlangage();
     
    	require('sioView.php');
    }
     
    function getProjet(){
    	$proj = new file();
    	$postproj = $proj->getProjet($_GET['id_langage']);
     
    	require('sioProjetView.php');
    }
     
    function getArticle(){
    	$article = new file();
    	$postarticle = $article->getArticle($_GET['id_projet']);
     
    	require('sioArticleView.php');
    }
     
    function projet(){
    	$projet = new file();
    	$postproj = $projet->projet($_GET['id_projet']);
     
    	require('sioProjetView.php');
    }
     
    function post(){
    	$post = new file();
    	$postarticle = $post->getArticle($_GET['id_projet']);
    	$articleview = $post->post($_GET['id_projet']);
     
    	require('sioPostView.php');
    }
    Ma class avec les requêtes SQL
    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
    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
    44
    45
     
    <?php
    require_once('bd.php');
     
    	class file extends bd{
    		public function getlangage(){
    			$bd = $this->bd_Connect();
    			$req = $bd->query('SELECT * FROM Langage');
     
    			return $req;
    		}
     
    		public function getProjet($id_langage){
    			$bd = $this->bd_Connect();
    			$req2 = $bd->prepare('SELECT id, title FROM Projet WHERE id_langague = ?');
    			$req2->execute(array($id_langage));
     
    			return $req2;
    		}
     
    		public function getArticle($id_fichier){
    			$bd = $this->bd_Connect();
    			$req3 = $bd->prepare('SELECT id, title, id_projet, type FROM Article WHERE id_projet = ?');
    			$req3->execute(array($id_fichier));
     
    			return $req3;
    		}
     
    		public function projet($id_projet){
    			$bd = $this->bd_Connect();
    			$req4 = $bd->prepare('SELECT id, title FROM Projet WHERE id = ?');
    			$req4->execute(array($id_projet));
     
    			return $req4;
    		}
     
    		public function post($id_projet){
    			$bd = $this->bd_Connect();
    			$req5 = $bd->prepare('SELECT * FROM Article WHERE id_projet = ?');
    			$req5->execute(array($id_projet));
    			$post = $req5->fetch();
     
    			return $req5;
    		}
    	}
    Dans la page d'affichage j'ai à un moment
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <?php 
    	ob_start(); 
    	echo $articleview['content'];
    	$content = ob_get_clean();
    ?>
    c'est de la d'où vient le problème et je ne sais pas vraiment comment le résoudre

    Merci de m'aider si possible..

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    à priori je dirais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <?php 
    	ob_start(); 
    	echo $articleview->content; // c'est un objet, pas un array
    	$content = ob_get_clean();
    ?>

  3. #3
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut
    Effectivement je n'ai plus l'erreur mais maintenant j'ai une autre erreur ...
    Notice: Undefined property: PDOStatement::$content in /Applications/MAMP/htdocs/Mon site/sioPostView.php on line 17
    Mais ma question est pourquoi c'est un objet alors que je veux récupérer le contenu de ma BDD ?

  4. #4
    Modérateur

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

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Citation Envoyé par WiZarD67 Voir le message
    Effectivement je n'ai plus l'erreur mais maintenant j'ai une autre erreur ...
    Notice: Undefined property: PDOStatement::$content in /Applications/MAMP/htdocs/Mon site/sioPostView.php on line 17
    Mais ma question est pourquoi c'est un objet alors que je veux récupérer le contenu de ma BDD ?

    Il faudrait voir le fichier require_once('bd.php'); pour savoir comment PDO est configuré.

  5. #5
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut
    oui pardon je l'ai oublié

    voici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
     
    	/**
    	 * BD CONNECT
    	 */
    	class bd{
    		protected function bd_Connect(){
    			$bd = new PDO('mysql:host=localhost;dbname=BDD_SP', 'root', 'root');
    			return $bd;
    		}
    	}

  6. #6
    Modérateur

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

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Rien ne dis que votre requête est retourné sous forme de StdClass

    on peux avoir le retour de :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
     
    <?php 
    	ob_start(); 
            echo '<pre>';
    	var_dump($articleview);
            echo '<pre/>';
    	$content = ob_get_clean();
    ?>

  7. #7
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut
    oui bien sûr voici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    object(PDOStatement)#5 (1) {
      ["queryString"]=>
      string(41) "SELECT * FROM Article WHERE id_projet = ?"
    }

  8. #8
    Invité
    Invité(e)
    Par défaut
    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
    	/**
    	 * BD CONNECT
    	 */
    	class bd{
    		protected function bd_Connect(){
    			$extraParams = array(
    				PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,		// rapport d'erreurs sous forme d'exceptions
    				PDO::ATTR_PERSISTENT => true, 		// Connexions persistantes
    				PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, 	// fetch mode
    				PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8"	// encodage UTF-8
    				);
    			$bd = new PDO('mysql:host=localhost;dbname=BDD_SP', 'root', 'root', $extraParams);
    			return $bd;
    		}
    	}
    Au choix (voir PDOStatement::fetch) :

    • PDO::FETCH_ASSOC: retourne un tableau indexé par le nom de la colonne comme retourné dans le jeu de résultats
    • PDO::FETCH_BOTH (défaut): retourne un tableau indexé par les noms de colonnes et aussi par les numéros de colonnes, commençant à l'index 0, comme retournés dans le jeu de résultats
    • PDO::FETCH_OBJ : retourne un objet anonyme avec les noms de propriétés qui correspondent aux noms des colonnes retournés dans le jeu de résultats
    • ...

  9. #9
    Modérateur

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

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Ok, donc cela dit que votre requête n'est pas éxécuté.

    Vous devez parcourir votre code, pour trouver oû vous pensez éxécuter ce code.

    Apporter aussi les modif de @jreaux62, cela permettras d'être plus clair.


    Citation Envoyé par WiZarD67 Voir le message
    oui bien sûr voici :

    object(PDOStatement)#5 (1) {
    ["queryString"]=>
    string(41) "SELECT * FROM Article WHERE id_projet = ?"
    }

  10. #10
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut
    D'accord merci déjà à vous deux ça m'aide je vais chercher cela et je reviens vers vous

  11. #11
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut
    je reviens vers vous mais je n'ai pas trouvé pourquoi ma requête ne s'exécute pas.. pourrai vous m'aider?

  12. #12
    Modérateur

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

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Ici tu te trompes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    public function post($id_projet){
    			$bd = $this->bd_Connect();
    			$req5 = $bd->prepare('SELECT * FROM Article WHERE id_projet = ?');
    			$req5->execute(array($id_projet));
    			$post = $req5->fetch();
     
    			return $req5;
    		}
    Ce n'est pas qu'il faut retourner, mais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    public function post($id_projet){
    			$bd = $this->bd_Connect();
    			$req5 = $bd->prepare('SELECT * FROM Article WHERE id_projet = ?');
    			$req5->execute(array($id_projet));
    			$post = $req5->fetch();
     
    			return $post;
    		}

  13. #13
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut
    Je m'étais aperçu de cette erreur.. mais maintenant cela me remet cette erreur :

    Fatal error: Uncaught Error: Call to a member function fetch() on array in /Applications/MAMP/htdocs/Mon site/sioPostView.php:6 Stack trace: #0 /Applications/MAMP/htdocs/Mon site/frontend.php(37): require() #1 /Applications/MAMP/htdocs/Mon site/compte_sio.php(31): post() #2 {main} thrown in /Applications/MAMP/htdocs/Mon site/sioPostView.php on line 6
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    <?php
    while ($article = $post->fetch()) {
    ?>
       <a href="compte_sio.php?action=post&amp;id_projet=<?= $_GET['id_projet']?>&amp;title=<?= $article['title'] ?>" style="text-decoration: none; color: black"><p class="navsio"><?= htmlspecialchars($article['title']) ?></p></a>
    <?php
    }
    $post->closeCursor();
    ?>
    Il faudrai que j'enlève le while ($article = $post->fetch()) ??? je ne sais pas vraiment mais le problème c'est que se while me permet de récupérer toute les lignes de ma BDD. Donc je ne sais plus quoi faire

  14. #14
    Modérateur

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

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    C'est une blague ?
    Etes-vous sur de savoir ce que vous faites ?

    dans cette partie du code, vous faites déjà le fetch, c'est d'ailleurs le résulta qui vous retournez

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    public function post($id_projet){
    			$bd = $this->bd_Connect();
    			$req5 = $bd->prepare('SELECT * FROM Article WHERE id_projet = ?');
    			$req5->execute(array($id_projet));
    			$post = $req5->fetch();
     
    			return $post;
    		}
    Donc plus besoin de fecth(), en plus fetch() ne retourne qu'une ligne, contrairement à fetchAll()

    Donc ceci devrais être bon

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
       <a href="compte_sio.php?action=post&amp;id_projet=<?= $_GET['id_projet']?>&amp;title=<?= $post['title'] ?>" style="text-decoration: none; color: black"><p class="navsio"><?= htmlspecialchars($post['title']) ?></p></a>

  15. #15
    Membre du Club
    Homme Profil pro
    Alternance
    Inscrit en
    Février 2019
    Messages
    59
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Alternance
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2019
    Messages : 59
    Points : 46
    Points
    46
    Par défaut
    Oui je sais se que je voudrai faire est cela fonctionne bien maintenant je me suis juste emmêler les pieds merci beaucoup problème résolue désolé du dérangement

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 01/02/2016, 15h57
  2. Cannot use object of type SoapFault as array
    Par sajodia dans le forum Bibliothèques et frameworks
    Réponses: 1
    Dernier message: 01/08/2012, 11h46
  3. [MySQL] Fatal error: Cannot use object of type PDOStatement as array
    Par picool dans le forum PHP & Base de données
    Réponses: 12
    Dernier message: 01/03/2012, 15h13
  4. [ZF 1.10] Cannot use object of type stdClass as array
    Par cyrux dans le forum Zend Framework
    Réponses: 12
    Dernier message: 16/08/2010, 14h25
  5. [PHP 5.2] Fatal error: Cannot use object of type CPanier as array in . .
    Par Gauldo dans le forum Langage
    Réponses: 10
    Dernier message: 12/01/2009, 13h53

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