Czym jest nawilżenie Doctrine? [Zamknięte]

90

Czytałem o nawodnieniu w dokumentacji doktryny, ale nadal nie rozumiem, co to jest.

Czy mógłby ktoś wyjaśnić?

Never_had_a_name
źródło
Dokumentacja Doctrine2 wyjaśniająca HYDRATION: doctrine-project.org/docs/orm/2.0/en/reference/…
Dawid Ohia
29
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:

  1. 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'];
    }
    
  2. 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();
    }
    
  3. 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.

Crozin
źródło
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ą.
Sean the Bean
2
$q->fetchOne(array(), Doctrine_Core::HYDRATE_ARRAY);

Zwróci tylko prostą tablicę zamiast obiektu kolekcji doktryny.

Jubayer Arefin
źródło