doctrineのドキュメントでハイドレーションについて読みましたが、それが何であるかまだ理解できません。
誰かが説明してもらえますか?
doctrineのドキュメントでハイドレーションについて読みましたが、それが何であるかまだ理解できません。
誰かが説明してもらえますか?
回答:
水和は、クエリ結果を返すために使用されるメソッドです。例えば:
HYDRATE_ARRAY -これにより、別の配列で表されるレコードの配列が返されます。
$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-これはオブジェクトのコレクション(Doctrine_Collection)を返します:
$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 -クエリの結果の最初の列の値を返します:
 $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)
さらにいくつかのメソッドがあります。それぞれについてドキュメントで読むことができます。
orderBy()これを処理してください)。それは、単一のスカラー値()、ネストされた配列が各データベースレコード()またはオブジェクトのコレクション()を表す配列または配列であるかどうかに関係なく、クエリ結果はどうなりますか。やるのvar_dump各ハイドレーションモードのクエリ結果に- 「?それがどのように機能するか」を参照してくださいするための最良の方法です HYDRATE_SINGULAR_SCALARHYDRATE_ARRAYHYDRATE_RECORD
                    HYDRATE_SINGULAR_SCALAR、未定義の定数エラーを返します。HYDRATE_SINGLE_SCALARは正しい。
                    Doctrine::HYDRATE_RECORD今知られているDoctrine::HYDRATE_OBJECT
                    $q->fetchOne(array(), Doctrine_Core::HYDRATE_ARRAY);doctrineコレクションオブジェクトの代わりに単純な配列だけを返します。