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

Zend_Db PHP Discussion :

Problème de récupération de l'adapter.. enfin je crois!


Sujet :

Zend_Db PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France, Gard (Languedoc Roussillon)

    Informations forums :
    Inscription : Mai 2007
    Messages : 2
    Par défaut Problème de récupération de l'adapter.. enfin je crois!
    Salut à tous !

    tout d'abord je suis nouveau dans le monde du php , mais je me suis rapidement lancer dans le ZF pour la realisation d'un projet. Donc soyez indulgent .

    Je desire basiquement récupérer des données de ma BDD via l'ORM.
    j'ai donc créer un classe metier 'page' dont voici la sommaire trame :
    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
     
    <?php
     
    Zend_loader::loadClass("Zend_Db_Table");
     
    class Page extends Zend_Db_Table_Abstract
    {
            protected $_name = 'page';    
    	protected $_primary = 'id';
            protected $_sequence = true;
     
    	public function findByName($psName)
            {
    		$where = $this->getAdapter()->quoteInto('nom = ?',(string)$psName);
    		return $this->fetchRow($where);
    	}	
    }
    dans mon controleur je veux juste tester quelque chose du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    	function init()
    	{
    		$this->moPage = new Page();	
    		$this->moView = Zend_registry::get('view');	
            }
     
            public function indexAction()
    	{			
    		$findedPages = $this->moPage->find(1);
    		echo $this->moView->render('scripts/gabarit.php');
           }

    et la patatra !! j'ai une belle erreur :

    Call to a member function quoteInto() on a non-object in D:\WWW\...\Zend\Db\Table\Abstract.php on line 628

    j'ai donc l'impression qu'il ne veut pas recuperer mon adapter que j'ai pourtant defini dans la page d'index comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    		$dbAdapter = Zend_Db::factory($config->db->adapter , $config->db->config->asArray());
    		Zend_Db_Table_Abstract::setDefaultAdapter($dbAdapter);


    je ne suis pas sur d'etre très clair , mais si quelqu'un avez un piste merci de bien vouloir me sortir de cette galère !!

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bizarre, je ne vois rien qui cloche, à part le fait que tu définisse une méthode findByName(), pour ne pas l'appeler dans le contrôleur, mais appeler find(), ce qui en soit est tout à fait légitime.

    Ton code ne comporte vraimant aucune erreur, si l'adapter avait buggué ( mauvais driver, mauvais identifiant à la base ) , il l'aurait signalé lors de l'instanciation de ta table ORM.

    L'erreur venant de chemin\Db\Table\Abstract.php ; c'est d'autant plus bizarre...

  3. #3
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France, Gard (Languedoc Roussillon)

    Informations forums :
    Inscription : Mai 2007
    Messages : 2
    Par défaut
    Merci pour ta réponse même si j'aurai préferé avoir fait une erreur qui règle illico le PB.

    ce qui est bizarre c'est que si je fait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    $oAdapter = $this->moPage->getAdapter();
    Zend_Debug::dump($oAdapter, $label='adapter : ', $echo=true);
    et bien comme résultat j'ai : NULL

    Hors il me semble qu'il devrait me renvoyer un Objet .


    Par contre si j'affiche les info de ma table :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    		$oPage = $this->moPage->info();
    		Zend_Debug::dump($oPage, $label='page : ', $echo=true);
    Voila ce quil me donne en retour

    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
     
    page : array(9) {
      ["schema"] => string(8) "site-epl"
      ["name"] => string(4) "page"
      ["cols"] => array(0) {
      }
      ["primary"] => array(1) {
        [0] => string(2) "id"
      }
      ["metadata"] => array(0) {
      }
      ["rowClass"] => string(17) "Zend_Db_Table_Row"
      ["rowsetClass"] => string(20) "Zend_Db_Table_Rowset"
      ["referenceMap"] => array(0) {
      }
      ["dependentTables"] => array(0) {
      }
    }
    ce qui m'inquete c'est le ["metadata"] => array(0) ;

    si ca peut vous donner des indices !!

  4. #4
    Invité
    Invité(e)
    Par défaut
    Il n'est pas normal qu'il retourne NULL.
    Il n'est pas non plus normal qu'il ne renvoie aucune exception.

    Il faut mettre à jour la version de ZF, et entammer un déboggage avancé.

Discussions similaires

  1. [TIBSQL] Problème de récupération d'un champs
    Par TitiFr dans le forum Bases de données
    Réponses: 6
    Dernier message: 07/08/2005, 13h33
  2. [hibernate]Problème de récupération d'objet...
    Par roxx62 dans le forum Hibernate
    Réponses: 1
    Dernier message: 07/07/2005, 11h36
  3. Réponses: 8
    Dernier message: 12/05/2005, 08h16
  4. Nouveau problème de récupération de valeurs.
    Par pmboutteau dans le forum ASP
    Réponses: 4
    Dernier message: 09/03/2005, 10h48
  5. Problème de récupération de texte de formulaire
    Par bigourson dans le forum Langage
    Réponses: 4
    Dernier message: 15/09/2004, 16h27

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