J'ai lu sur l'hydratation dans la documentation de la doctrine, mais je ne comprends toujours pas ce que c'est.
Quelqu'un pourrait-il expliquer?
J'ai lu sur l'hydratation dans la documentation de la doctrine, mais je ne comprends toujours pas ce que c'est.
Quelqu'un pourrait-il expliquer?
Réponses:
L'hydratation est une méthode utilisée pour renvoyer les résultats de la requête. Par exemple:
HYDRATE_ARRAY
- Cela vous retournera un tableau d'enregistrements qui sont représentés par un autre tableau:
$q = Doctrine_Query::create()
->from('Post p')
->setHydrationMode(Doctrine::HYDRATE_ARRAY);
$resultSet = $q->execute(); // $resultSet is an array
foreach ($resultSet as $post) {
// $post is an array
echo $post['title'];
}
HYDRATE_RECORD
- Cela vous retournera une collection ( Doctrine_Collection ) d'objets:
$q = Doctrine_Query::create()
->from('Post p')
->setHydrationMode(Doctrine::HYDRATE_RECORD); // Unnecessary, HYDATE_RECORD is default method
$resultSet = $q->execute(); // $resultSet is an Doctrine_Collection object
foreach ($resultSet as $post) {
// $post is an Post object
echo $post->getTitle();
echo $post['title']; // Each Doctrine's Model object implements ArrayAccess interface so this is possible
echo $post->myCustomMethod();
}
HYDRATE_SINGULAR_SCALAR
- Renvoie la valeur de la première colonne du résultat de la requête:
$q = Doctrine_Query::create()
->select('p.created_at')
->from('Post p')
->where('p.id = ?', 321)
->setHydrationMode(Doctrine::HYDRATE_SINGULAR_SCALAR);
$createdAt = $q->execute(); // $createdAt has value of first column from first record from result set (eg.: 2008-04-06 21:22:35)
Il existe quelques méthodes supplémentaires, vous pouvez en savoir plus sur chacune dans la documentation.
orderBy()
gérer cela). Il s'agit de savoir quel sera le résultat de votre requête , qu'il s'agisse d'une seule valeur scalaire ( HYDRATE_SINGULAR_SCALAR
), d'un tableau ou de tableaux où les tableaux imbriqués représentent chaque enregistrement de base de données ( HYDRATE_ARRAY
) ou une collection d'objets ( HYDRATE_RECORD
). Faites var_dump le résultat de la requête pour chaque mode d'hydratation - « comment ça marche » qui est la meilleure façon de voir
HYDRATE_SINGULAR_SCALAR
renvoie une erreur constante non définie. HYDRATE_SINGLE_SCALAR
est correct.
Doctrine::HYDRATE_RECORD
est maintenant connue sous le nom deDoctrine::HYDRATE_OBJECT
$q->fetchOne(array(), Doctrine_Core::HYDRATE_ARRAY);
Il renverra juste un simple tableau au lieu d'un objet de collection doctrine.