Relations Zend_Db_Table

Zend_Db_Table_Definition

Introduction

Zend_Db_Table_Definition est une classe qui peut être utilisée pour décrire les relations et les options de configuration qui devraient être utilisées lorsque Zend_Db_Table est manipulée par instantiation concrête.

Utilisation de base

Les options décrites dans un objet de définition sont les mêmes que celles qu'utilisent les classes étendant Zend_Db_Table_Abstract. Votre objet de définition peut alors être passé à la classe à l'instanciation, celle-ci connaitra alors la définition de toutes les tables concernées.

Voici un exemple d'objet de définition qui va décrire les noms des tables et les relations entre les objets supports de ces tables. Note: Si 'name' n'est pas précisé, la clé servira alors de nom à la table, c'est le cas dans notre exemple avec 'genre'.

Example #1 Décrire un modèle de base de données

  1. $definition = new Zend_Db_Table_Definition(array(
  2.     'author' => array(
  3.         'name' => 'author',
  4.         'dependentTables' => array('book')
  5.         ),
  6.     'book' => array(
  7.         'name' => 'book',
  8.         'referenceMap' => array(
  9.             'author' => array(
  10.                 'columns' => 'author_id',
  11.                 'refTableClass' => 'author',
  12.                 'refColumns' => 'id'
  13.                 )
  14.             )
  15.         ),
  16.     'genre' => null,
  17.     'book_to_genre' => array(
  18.         'referenceMap' => array(
  19.             'book' => array(
  20.                 'columns' => 'book_id',
  21.                 'refTableClass' => 'book',
  22.                 'refColumns' => 'id'
  23.                 ),
  24.             'genre' => array(
  25.                 'columns' => 'genre_id',
  26.                 'refTableClass' => 'genre',
  27.                 'refColumns' => 'id'
  28.                 )
  29.             )
  30.         )
  31.     ));

Comme vous le voyez, les mêmes options que vous utilisez en général en étendant Zend_Db_Table_Abstract sont présentes dans ce tableau. Cette définition va persister vers toutes les tables qui seront créees par votre objet, ceci assure une isolation et un bon fonctionnement.

Ci-après un exemple d'instanciation d'une table et de l'utilisation de findDependentRowset() et findManyToManyRowset() qui vont correspondre au modèle de données:

Example #2 Intéragir avec la définition utilisée

  1. $authorTable = new Zend_Db_Table('author', $definition);
  2. $authors = $authorTable->fetchAll();
  3.  
  4. foreach ($authors as $author) {
  5.     echo $author->id . ': ' . $author->first_name . ' ' . $author->last_name . PHP_EOL;
  6.     $books = $author->findDependentRowset('book');
  7.     foreach ($books as $book) {
  8.         echo '    Book: ' . $book->title . PHP_EOL;
  9.         $genreOutputArray = array();
  10.         foreach ($book->findManyToManyRowset('genre', 'book_to_genre') as $genreRow) {
  11.             $genreOutputArray[] = $genreRow->name;
  12.         }
  13.         echo '        Genre: ' . implode(', ', $genreOutputArray) . PHP_EOL;
  14.     }
  15. }

Utilisation avancée

Quelques fois vous voudriez mixer les utilisations, via la définition et une extension concrête de Zend_Db_Table_Abstract. Pour ce faire, omettez de spécifier une définition concernant la classe concrête. Zend_Db_Table utiisera alors l'instance que vous lui passerez.

Dans l'exemple d'après, nous allons placer une des tables sous forme de classe concrête, et laisser les autres sous forme de définitions. Nous allons voir alors comment les faire intéragir.

Example #3 Mixer la définition et l'extension concrête

  1. class MyBook extends Zend_Db_Table_Abstract
  2. {
  3.     protected $_name = 'book';
  4.     protected $_referenceMap = array(
  5.         'author' => array(
  6.             'columns' => 'author_id',
  7.             'refTableClass' => 'author',
  8.             'refColumns' => 'id'
  9.             )
  10.         );
  11. }
  12.  
  13. $definition = new Zend_Db_Table_Definition(array(
  14.     'author' => array(
  15.         'name' => 'author',
  16.         'dependentTables' => array('MyBook')
  17.         ),
  18.     'genre' => null,
  19.     'book_to_genre' => array(
  20.         'referenceMap' => array(
  21.             'book' => array(
  22.                 'columns' => 'book_id',
  23.                 'refTableClass' => 'MyBook',
  24.                 'refColumns' => 'id'
  25.                 ),
  26.             'genre' => array(
  27.                 'columns' => 'genre_id',
  28.                 'refTableClass' => 'genre',
  29.                 'refColumns' => 'id'
  30.                 )
  31.             )
  32.         )
  33.     ));
  34.  
  35. $authorTable = new Zend_Db_Table('author', $definition);
  36. $authors = $authorTable->fetchAll();
  37.  
  38. foreach ($authors as $author) {
  39.     echo $author->id . ': ' . $author->first_name . ' ' . $author->last_name . PHP_EOL;
  40.     $books = $author->findDependentRowset(new MyBook());
  41.     foreach ($books as $book) {
  42.         echo '    Book: ' . $book->title . PHP_EOL;
  43.         $genreOutputArray = array();
  44.         foreach ($book->findManyToManyRowset('genre', 'book_to_genre') as $genreRow) {
  45.             $genreOutputArray[] = $genreRow->name;
  46.         }
  47.         echo '        Genre: ' . implode(', ', $genreOutputArray) . PHP_EOL;
  48.     }
  49. }

Relations Zend_Db_Table