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 :

Call to a member function setFetchMode() on a non-object [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Inscrit en
    Novembre 2006
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 22
    Points : 17
    Points
    17
    Par défaut Call to a member function setFetchMode() on a non-object
    Bonjour à tous,

    Voila je recommance depuis peu a programmer. J'ai voulu me former au php mais voila j'ai un problème avec la PDO

    Voici ma source :

    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
    <?php
    class news{
     
    	# Attribution des variables
     
    	public $connection;
    	#Fonction construct
     
    	public function __construct($PARM_HOSTNAME, $PARM_DATABASE, $PARM_USER, $PARM_PASSWORD){
     
    		try{
    			$this->connection = new PDO('mysql:host='.$PARM_HOSTNAME.';dbname='.$PARM_DATABASE, $PARM_USER ,$PARM_PASSWORD);
    		}
    		catch(PDOException $e){
    			echo 'Connection failed: ' . $e->getMessage();
    		}
     
    	}
     
    	public function selectNews(){
     
    		$result	= $this->connection->query('SELECT * FROM news');
    		$result->setFetchMode(PDO::FETCH_OBJ);
    		while($data = $result->fetch())
    		{
    			echo 'Voici une news :' . $data->contentNews . ' <br />';
    		}
     
    	}
     
    }
     
    ?>
    et mon problème ce trouve si php ne dit pas de connerie ici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $result->setFetchMode(PDO::FETCH_OBJ);
    J'obtien l'erreur suivante :

    Fatal error: Call to a member function setFetchMode() on a non-object in C:\wamp\www\Test\News\lib\classwork\news.php on line 32
    Je voudrai juste ne pas avoir de problème.

    Je vous remercie d'avance pour vos futures réponses.

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Fais un var_dump($result); avant pour voir.

  3. #3
    Membre à l'essai
    Inscrit en
    Novembre 2006
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 22
    Points : 17
    Points
    17
    Par défaut
    j'obtiens un booléen false

  4. #4
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    fait un var_dump($this->connection); alors.

    tu es sur de ta requête ?

  5. #5
    Membre à l'essai
    Inscrit en
    Novembre 2006
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 22
    Points : 17
    Points
    17
    Par défaut
    Oui je suis bien sur ma requête:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <?php
    public function selectNews(){
     
    		$result	= $this->connection->query('SELECT * FROM news');
    		var_dump($this->connection);
    		$result->setFetchMode(PDO::FETCH_OBJ);
    		while($data = $result->fetch())
    		{
    			echo 'Voici une news :' . $data->contentNews . ' <br />';
    		}
    ?>
    et j'obtiens ceci :

    object(PDO)#2 (0) { }

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Affiche les erreurs :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    try{
    			$this->connection = new PDO('mysql:host='.$PARM_HOSTNAME.';dbname='.$PARM_DATABASE, $PARM_USER ,$PARM_PASSWORD);
    $this->connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
     
    		}

  7. #7
    Membre à l'essai
    Inscrit en
    Novembre 2006
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 22
    Points : 17
    Points
    17
    Par défaut
    voici ce que j'obtiens :

    Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[3D000]: Invalid catalog name: 1046 No database selected' in C:\wamp\www\Test\News\lib\classwork\news.php:33 Stack trace: #0 C:\wamp\www\Test\News\lib\classwork\news.php(33): PDO->query('SELECT * FROM n...') #1 C:\wamp\www\Test\News\index.php(10): news->selectNews() #2 {main} thrown in C:\wamp\www\Test\News\lib\classwork\news.php on line 33

  8. #8
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    Le nom de ta base de donnée n'est apparement pas bon.

  9. #9
    Membre à l'essai
    Inscrit en
    Novembre 2006
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 22
    Points : 17
    Points
    17
    Par défaut
    J'ai compris mon problème j'ai essayer de modifier des valeurs constantes...

    Désoler pour le dérangement

    Merci pour votre aide

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

Discussions similaires

  1. PDO: Call to a member function setFetchMode() on a non-objec
    Par bedissa84 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 02/06/2014, 10h46
  2. [PDO] Fatal error: Call to a member function setFetchMode() on a non-object
    Par cissok dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 11/02/2014, 16h16
  3. Réponses: 4
    Dernier message: 07/10/2009, 11h53
  4. [PDO] Fatal error: Call to a member function setFetchMode() on a non-object in
    Par tores20 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 28/07/2009, 23h04
  5. Réponses: 9
    Dernier message: 05/07/2007, 11h25

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