什么是学说水合作用?

nev*_*ame 90 php doctrine hydration

我已经读过关于学说文献中的水合作用,但我仍然无法理解它是什么.

有人可以解释一下吗?

Cro*_*zin 92

水合是一种用于返回查询结果的方法.例如:

  1. 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'];
    }
    
    Run Code Online (Sandbox Code Playgroud)
  2. 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();
    }
    
    Run Code Online (Sandbox Code Playgroud)
  3. 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)
    
    Run Code Online (Sandbox Code Playgroud)

还有一些方法,您可以在文档中阅读每个方法.

  • 不,这不是关于排序结果(`orderBy()`处理这个).它是关于*你的查询结果是什么*,它是一个标量值(`HYDRATE_SINGULAR_SCALAR`),一个或多个数组,其中嵌套数组代表每个数据库记录(`HYDRATE_ARRAY`)或一组对象(`HYDRATE_RECORD` ).针对每个水合模式的查询结果执行[var_dump](http://pl.php.net/manual/en/function.var-dump.php) - 这是查看"它是如何工作的"的最佳方式吗? (4认同)
  • 只是一个小小的提示.在1.2`HYDRATE_SINGULAR_SCALAR`中返回一个未定义的常量错误.`HYDRATE_SINGLE_SCALAR`是对的. (4认同)