• Willkommen im Zend Framework Forum

    ZF1 Zend Framework 1 + ZF2 Zend Framework 2

    Das Zend Framework Forum ist seit 2006 die erste Anlaufstelle für Zend Framework Entwickler in Deutschland. Mit über 70.000 Beiträgen und einer steigenden Nutzerzahl bietet das Forum hilfreiche Themen und ZF-Tutorials für professionelle Entwickler, fortgeschrittene Programmierer sowie Zend Framework Einsteiger.
    Wenn dies Dein erster Besuch in der Zend Framework Community ist, lies bitte zuerst die Hilfe - FAQ durch. Du musst Dich registrieren, bevor Du Beiträge verfassen kannst. Klicke oben auf 'Registrieren', um die Registrierung zu starten. Du kannst auch jetzt schon Beiträge lesen. Hier im Forum findest Du die Zend Framework Hilfe, die Du suchst!

    Grüße an alle Zend Framework Entwickler. Das Team vom Zend Framework Forum!

    Drupal Agentur

Hydrator in mehreren Joins

codescratch

New member
Hi,

ich habe drei Tabellen, die miteinander über Foreign-Key verknüpft.
Sowie hier unten dargestellt:

Bildschirmfoto 2017-04-27 um 18.45.02.jpg





Ich mache Joins über Tablegateway. Ich bekomme aber nicht das Objekt "Language" zu "Movie" hydriert.


In meiner DbStorage habe ich :


PHP:
public function fetchDvdCollection(){
    $select = $this->tableGateway->getSql()->select();
    $select = $this->addMovieJoinToSelect(select);
    $select = $this->addLanguageJoinToSelect(select);
 
   $resultSet = $this->tableGateway->selectWith($select);
    ...
}

private function addMovieJoinToSelect(Select $select){
    $select ->join('MOVIE'), 'DVD.MOVIE_ID = MOVIE.ID', [
        'MOVIE_ID' => 'ID',
        'MOVIE_ID' => 'LANGUAGE_ID',
    ]);
    return $select; 
}

private function addLANGUAGEJoinToSelect(Select $select){
    $select ->join('LANGUAGE'), 'DVD.LANGUAGE_ID = LANGUAGE.ID', [
        'LANGUAGE_ID' => 'ID',
        'LANGUAGE_LANGUAGE' => 'LANGUAGE',
    ]);
    return $select;
 }

Und in die Beiden EntityStrategy Hydrator:
PHP:
class MovieEntityStrategy implements StrategyInterface{
...
  public function hydrate($value, $data = [])
      {
          $movieData = [];
          foreach ($data as $key => $value) {
              if (substr($key, 0, 6) != 'MOVIE_') {
                  continue;
              }
              $movieData[substr($key, 6)] = $value;
          }
          $movieEntity = new MovieEntity();
          $this->hydrator->hydrate($movieData, $movieEntity);
          return $movieEntity;
      }
}

class LanguageEntityStrategy implements StrategyInterface{
...
  public function hydrate($value, $data = [])
      {
          $languageData = [];
          foreach ($data as $key => $value) {
              if (substr($key, 0, 9) != 'LANGUAGE_') {
                  continue;
              }
              $languageData[substr($key, 9)] = $value;
          }
          $languageEntity = new LanguageEntity();
          $this->hydrator->hydrate($languageData, $languageEntity);
          return $companyEntity;
      }
}

Dann letztendlich in der Konstraktor meiner DvDHydrator-Klassen:
PHP:
...  

$this->addStrategy('MOVIE_ID', new MovieEntityStrategy(new MovieHydrator)));

// Das ist definitiv falsch  
// Ich bin nicht sicher wie ich hier mache?  
$this->addStrategy('LANGUAGE_ID', new LanguageEntityStrategy(new LanguageHydrator)));

...

Das Entity "Movie" ist auf jedenfall in Entity "DvD" gemappt.
Wie kann ich hinkriegen, dass das Entity "Language" in das Entity "Movie" hydriert und gemappt ist?


Danke im Voraus.


Schöne Grüße,


Codescratch
 

Anhänge

Oben