Apa Doktrin hidrasi? [Tutup]

90

Saya telah membaca tentang hidrasi dalam dokumentasi doktrin tetapi saya masih tidak dapat memahami apa itu hidrasi.

Bisakah seseorang menjelaskan?

never_had_a_name
sumber
Doctrine2 referensi dokumentasi yang menjelaskan HIDRASI: doctrine-project.org/docs/orm/2.0/en/reference/...
Dawid Ohia
29
Tidak konstruktif? Ini adalah salah satu konsep paling mendasar untuk memahami bagaimana internal Ajaran bekerja.
csvan
6
Saya pikir pertanyaan ini harus dilindungi daripada ditutup.
Simon
2
@Setuju Pertanyaan dan jawaban yang diterima sama-sama populer, mengapa tidak dipindahkan ke status terlindungi ?
Denis Kulagin

Jawaban:

92

Hidrasi adalah metode yang digunakan untuk mengembalikan hasil kueri. Sebagai contoh:

  1. HYDRATE_ARRAY - Ini akan mengembalikan Anda array record yang diwakili oleh array lain:

    $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- Ini akan mengembalikan Anda koleksi ( Doctrine_Collection ) objek:

    $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 - Akan mengembalikan nilai kolom pertama hasil query:

     $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)
    

Ada beberapa metode lagi, Anda dapat membaca masing-masing di dokumentasi.

Crozin
sumber
ok..jadi biasanya ketika saya menggunakan sql itu mengembalikan objek mysql dan saya harus menggunakan mysqli_fetch_assoc, kemudian mengurutkannya sendiri dan seterusnya ... tapi sekarang semuanya diurutkan untuk saya. Itulah tentang hidrasi, memberi saya objek / array yang diurutkan?
never_had_a_name
4
Tidak, ini bukan tentang menyortir hasil ( orderBy()menangani ini). Ini tentang Apa yang akan dihasilkan kueri Anda , apakah itu akan berupa nilai skalar tunggal ( HYDRATE_SINGULAR_SCALAR), larik atau larik di mana larik bersarang mewakili setiap catatan database ( HYDRATE_ARRAY) atau kumpulan objek ( HYDRATE_RECORD). Lakukan var_dump pada hasil kueri untuk setiap mode hidrasi - itulah cara terbaik untuk melihat "cara kerjanya?"
Crozin
4
hanya sedikit tip. Dalam 1.2 HYDRATE_SINGULAR_SCALARmengembalikan kesalahan konstan yang tidak ditentukan. HYDRATE_SINGLE_SCALARbenar.
Darmen Amanbayev
1
Sebagai catatan Doctrine::HYDRATE_RECORDsekarang dikenal sebagaiDoctrine::HYDRATE_OBJECT
Steve Tauber
1
Tautan ke dokumentasi yang disebutkan di atas akan membuat jawaban ini lebih bermanfaat.
Sean the Bean
2
$q->fetchOne(array(), Doctrine_Core::HYDRATE_ARRAY);

Ini hanya akan mengembalikan array sederhana daripada objek koleksi doktrin.

Jubayer Arefin
sumber