Czytałem o nawodnieniu w dokumentacji doktryny, ale nadal nie rozumiem, co to jest.
Czy mógłby ktoś wyjaśnić?
Czytałem o nawodnieniu w dokumentacji doktryny, ale nadal nie rozumiem, co to jest.
Czy mógłby ktoś wyjaśnić?
Odpowiedzi:
Hydration to metoda używana do zwracania wyników zapytania. Na przykład:
HYDRATE_ARRAY
- To zwróci tablicę rekordów, które są reprezentowane przez inną tablicę:
$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
- To zwróci Ci kolekcję ( Doctrine_Collection ) obiektów:
$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
- Zwróci wartość pierwszej kolumny wyniku zapytania:
$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)
Jest jeszcze kilka metod, o których możesz przeczytać w dokumentacji.
orderBy()
obsłuż to). Chodzi o to, jaki będzie wynik zapytania , czy będzie to pojedyncza wartość skalarna ( HYDRATE_SINGULAR_SCALAR
), tablica lub tablice, w których zagnieżdżone tablice reprezentują każdy rekord bazy danych ( HYDRATE_ARRAY
) lub zbiór obiektów ( HYDRATE_RECORD
). Czy var_dump w wynikach zapytania dla każdego trybu nawodnienia - to najlepszy sposób, aby zobaczyć, „jak to działa?”
HYDRATE_SINGULAR_SCALAR
zwraca niezdefiniowany stały błąd. HYDRATE_SINGLE_SCALAR
jest w porządku.
Doctrine::HYDRATE_RECORD
jest teraz znany jakoDoctrine::HYDRATE_OBJECT
$q->fetchOne(array(), Doctrine_Core::HYDRATE_ARRAY);
Zwróci tylko prostą tablicę zamiast obiektu kolekcji doktryny.