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 :

Tuto d'Akrabat ne fonctionne pas avec une autre table dans une autre base de donnees


Sujet :

Zend_Db PHP

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    34
    Détails du profil
    Informations personnelles :
    Localisation : Luxembourg

    Informations forums :
    Inscription : Janvier 2007
    Messages : 34
    Points : 37
    Points
    37
    Par défaut Tuto d'Akrabat ne fonctionne pas avec une autre table dans une autre base de donnees
    Si je crée une table "regions" dans la base de données existante "zftest" du tuto d'Akrabat, je ne peux pas appeler cette table

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <?php foreach($this->regions as $regions) : ?>
    Warning: Invalid argument supplied for foreach() in /Applications/MAMP/htdocs/zf-tutorial/application/
    views/indexIndex.tpl.php on line 10
    et réciproquement
    dans une nouvelle base de données qui contient déja une table "regions" j'ai la même erreur si j'y crée une table "album" et que j'essaye de l' appeler !

    Dans cette nouvelle base de données (alors que cela ne marche pas pour la table "album") je peux par contre appeler sans problème la table "regions".
    Mais ce n'est pas parfait non plus car cela ne fonctionne qu'avec le premier champ 'id'. Le second champ 'regionlib' me renvoie une erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    
    <?php foreach($this->regions as $regions) : ?>
    <tr>
    	<td><?php echo $this->escape($regions->regionlib);?></td>
    Fatal error: Uncaught exception 'Zend_Db_Table_Row_Exception' with message 
    'column 'regionlib' not in row' in /Applications/MAMP/htdocs/library08/Zend/Db/Table/Row.php:97 Stack tr 
    la table region est la suivante :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    CREATE TABLE `regions` (
      `id` tinyint(4) NOT NULL auto_increment,
      `regionlib` varchar(15) NOT NULL,
      `paysid` tinyint(4) NOT NULL,
      PRIMARY KEY  (`id`)
    ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=7 ;
     
    INSERT INTO `regions` VALUES (1, 'North', 1);
    INSERT INTO `regions` VALUES (2, 'North East', 1);
    INSERT INTO `regions` VALUES (4, 'South', 1);
    INSERT INTO `regions` VALUES (3, 'Central', 1);
    INSERT INTO `regions` VALUES (6, 'East', 1);
    la table album est la suivante :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    CREATE TABLE `album` (
      `id` int(11) NOT NULL auto_increment,
      `artist` varchar(100) NOT NULL,
      `title` varchar(100) NOT NULL,
      PRIMARY KEY  (`id`),
      UNIQUE KEY `artist` (`artist`)
    ) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=8 ;
     
     
    INSERT INTO `album` VALUES (6, 'qweeree', 'tytyt');
    INSERT INTO `album` VALUES (7, 'wghggh', 'ggg');


    Y a-t-il quelqu'un qui a le tuto d'Akrabat et qui pourrait essayer pour voir s'il a le problème ?

    Eric

  2. #2
    Membre confirmé Avatar de goodpz
    Profil pro
    Inscrit en
    Février 2007
    Messages
    475
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 475
    Points : 514
    Points
    514
    Par défaut
    Quels sont les noms réels des champs dans ta table ? Il y a une transformation automatique undercase/camelcase qui est opérée par Zend_DB

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    34
    Détails du profil
    Informations personnelles :
    Localisation : Luxembourg

    Informations forums :
    Inscription : Janvier 2007
    Messages : 34
    Points : 37
    Points
    37
    Par défaut
    J'ai mis à jour mon post ci-dessus

  4. #4
    Membre confirmé Avatar de goodpz
    Profil pro
    Inscrit en
    Février 2007
    Messages
    475
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 475
    Points : 514
    Points
    514
    Par défaut
    Etrange car ton code ne semble pas concerné par des bugs connus (http://framework.zend.com/issues/browse/ZF-50 , http://framework.zend.com/issues/browse/ZF-445) relatifs aux transformations camelcase.

    Ceci fonctionne chez moi avec exactement les même tables et données:

    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
    require_once 'Zend/Db.php';
    require_once 'Zend/Db/Table.php';
    $params = array (
      'host'     => '..',
      'username' => '..',
      'password' => '..',
      'dbname'   => 'zftest'
    );
    $db = Zend_Db::factory('PDO_MYSQL', $params);
    Zend_Db_Table::setDefaultAdapter($db);
     
    class Regions extends Zend_Db_Table {}
    echo '<pre>';
    $rtable = new Regions();
    $regions = $rtable->fetchAll();
    foreach ($regions as $region) {
      echo $region->id."\n";
      echo $region->regionlib."\n";
      echo $region->paysid."\n";
    }
    print_r($regions);
    Que t'indique un print_r($regions) ou print_r($rtable), plus particulièrement l'attribut protected _cols de l'objet Regions ?

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    34
    Détails du profil
    Informations personnelles :
    Localisation : Luxembourg

    Informations forums :
    Inscription : Janvier 2007
    Messages : 34
    Points : 37
    Points
    37
    Par défaut
    merci pour ta réponse , c'est en voyant ton code que j'ai compris mon erreur
    au niveau de
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $regions = $rtable->fetchAll();

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

Discussions similaires

  1. Champs identiques avec valeur différente where dans une même table
    Par Cyrus59 dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 17/11/2014, 16h56
  2. [AC-2010] INSERT SELECT avec union de 2 tables dans une nouvelle table
    Par Nikimizi dans le forum Requêtes et SQL.
    Réponses: 0
    Dernier message: 31/07/2014, 13h51
  3. Réponses: 0
    Dernier message: 10/07/2012, 00h14
  4. Requête SQL dynamique avec nom de table dans une variable
    Par jonjack dans le forum SQL Procédural
    Réponses: 9
    Dernier message: 15/09/2011, 14h37
  5. plusieurs tables dans une seule table
    Par scully2501 dans le forum Access
    Réponses: 1
    Dernier message: 10/10/2005, 09h19

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