Nie konstruktywne? Jest to jedno z najbardziej fundamentalnych pojęć pozwalających zrozumieć, jak działają elementy wewnętrzne Doktryny.
csvan
6
Myślę, że to pytanie powinno być raczej chronione niż zamykane.
Simon
2
@Simon Zgadzam się. Pytanie i zaakceptowana odpowiedź są popularne, dlaczego więc nie przenieść go do stanu chronionego ?
Denis Kulagin,
Odpowiedzi:
92
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 arrayforeach ($resultSet as $post) {
// $post is an arrayecho $post['title'];
}
$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 objectforeach ($resultSet as $post) {
// $post is an Post objectecho $post->getTitle();
echo $post['title']; // Each Doctrine's Model object implements ArrayAccess interface so this is possibleecho $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.
ok… normalnie, kiedy używam sql, zwraca obiekt mysql i muszę użyć mysqli_fetch_assoc, a następnie posortować je samodzielnie i tak dalej ... ale teraz wszystko jest dla mnie posortowane. o to chodzi w nawadnianiu, dając mi posortowane obiekty / tablice?
never_had_a_name
4
Nie, nie chodzi o sortowanie wyników ( 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?”
Crozin
4
tylko mała wskazówka. W 1.2 HYDRATE_SINGULAR_SCALARzwraca niezdefiniowany stały błąd. HYDRATE_SINGLE_SCALARjest w porządku.
Darmen Amanbayev
1
Jako notatka Doctrine::HYDRATE_RECORDjest teraz znany jakoDoctrine::HYDRATE_OBJECT
Steve Tauber
1
Link do wyżej wymienionej dokumentacji uczyniłby tę odpowiedź bardziej pomocną.
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.
źródło
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.
źródło