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_SCALAR
HYDRATE_ARRAY
HYDRATE_RECORD
HYDRATE_SINGULAR_SCALAR
、未定義の定数エラーを返します。HYDRATE_SINGLE_SCALAR
は正しい。
Doctrine::HYDRATE_RECORD
今知られているDoctrine::HYDRATE_OBJECT
$q->fetchOne(array(), Doctrine_Core::HYDRATE_ARRAY);
doctrineコレクションオブジェクトの代わりに単純な配列だけを返します。