1

我有一个模型,评论,它属于模块、照片、评论、文章和用户。反过来,这些模型中的每一个都有许多评论。

用户属于头像,头像有很多用户

在下面的代码中,我成功检索了最新的 5 条评论,无论它们来自什么模型(照片、文章、评论),并且我显示了有关用户的一些信息(用户名、在线状态)。

$recentComments = $this->find('all',
array(
    'limit' => '5',
    'order' => array('Comment.id' => 'desc'),
    'conditions' => array(
        'Comment.page_id' => $page_id
    ),
    'contain' => array(
        'Photo' => array(
            'fields' => array('Photo.id'),
            'conditions' => array(
                'Comment.module_id' => 8
            ),
        ),
        'Review' => array(
            'fields' => array('Review.title', 'Review.id'),
            'conditions' => array(
                'Comment.module_id' => 2
            ),
        ),
        'Article' => array(
            'fields' => array('Article.title', 'Article.id'),
            'conditions' => array(
                'Comment.module_id' => 3
            ),
        ),
       'Module' => array(
            'fields' => array('Module.model', 'Module.post_title'),
        ),
      'User' => array(
            'fields' => array('User.username', 'User.online'),
        ),
    )
));

不幸的是,这存在一些问题。正如您在上面看到的,我不包含 User->Avatar 并且所有预期的数据都已成功检索。

$recentComments = Array
(
    [0] => Array
        (
            [Comment] => Array
                (
                    [id] => 179
                    [page_id] => 2
                    [module_id] => 3
                    [page] => 
                    [user_id] => 29
                    [post_id] => 9
                    [title] => test comment for article 9
                    [content] => here is the content for the comment
                    [created] => 2013-04-24 00:00:00
                    [redeemed] => 0
                    [status] => 0
                )

            [User] => Array
                (
                    [username] => bowlerae
                    [online] => 0
                )

            [Module] => Array
                (
                    [model] => Article
                    [post_title] => title
                )

            [Article] => Array
                (
                    [title] => Test title for article 9
                    [id] => 9
                    [likes] => 0
                    [dislikes] => 0
                    [comments] => 2
                )

            [Photo] => Array
                (
                    [id] => 
                )

            [Review] => Array
                (
                    [title] => 
                    [id] => 
                )

        )

但是,如果我确实包含这样的 User-> Avatar ......

   'User' => array(
        'fields' => array('User.username', 'User.online'),
        'Avatar' => array(
            'fields' => array('Avatar.file')
        )
    ),

然后递归基本上变得无限,与评论,用户,模块,文章,照片和评论相关的所有模型也被检索到了很多。

谁能解释为什么会这样?如果需要,我很乐意从某些模型中提交更多代码,但我没有看到任何问题。

看看另一个成功的例子……下面我正在检索最近的 5 篇文章。成功检索到包括用户头像在内的所有信息。

        $this->set('articles_sidebar', ClassRegistry::init('Article')->find('all',
array(
    'limit' => '5',
    'order' => array('Article.id' => 'desc'),
    'conditions' => array('
        Article.page_id' => $page_id
    ),
    'contain' => array(
       'User' => array(
            'fields' => array('User.username', 'User.online'),
            'Avatar' => array(
                'fields' => array('Avatar.file')
            )
        ),
    )
)));

请注意,鉴于 $page_id > 0,这两个查找是在 beforeRender 的 AppController 中执行的。 $page_id 设置在当前控制器的任何位置。我知道人们可能会问这个问题,但这不是问题所在,因为我提到示例 2 检索最近的文章目前有效。

编辑:我发现这与我在 Article 模型中的 afterfind 回调有关。有没有办法可以调整 afterfind 和/或 $recentComments 查询中的查询,以便它们仍然可以工作而不会破坏我的包含?我的 $recentComments 查询中不需要喜欢、不喜欢或评论虚拟字段,这就是为什么它们没有被列为包含字段之一的原因。

function afterFind($results, $primary = false) {
parent::afterFind($results, $primary);


          foreach($results as $key => $val){
               if (isset($val['Article']['id'])){    

                        $results[$key]['Article']['likes'] = $this->Like->find('count', array('conditions' => array('Like.post_id' => $results[$key]['Article']['id'], 'Like.module_id' => 3, 'Like.status' => 0)));


                        $results[$key]['Article']['dislikes'] = $this->Like->find('count', array('conditions' => array('Like.post_id' => $results[$key]['Article']['id'], 'Like.module_id' => 3, 'Like.status' => 1)));


                        $results[$key]['Article']['comments'] = $this->Comment->find('count', array('conditions' => array('Comment.post_id' => $results[$key]['Article']['id'], 'Comment.module_id' => 3, 'Comment.status < 2')));
               }
          } // end for each


      return $results;

} // end afterfind
4

2 回答 2

0

我的猜测是你的问题是这样的:

当使用 'fields' 和 'contain' 选项时 - 小心包含您的查询直接或间接需要的所有外键。

确保您包含用于加入用户和头像模型的任何字段。

(在这里阅读)

于 2013-04-25T04:34:56.197 回答
0

现在我改变了(在文章模型afterFind中)

 if (isset($val['Article']['id']))

 if (isset($val['Article']['id']) && $val == "article")

似乎在当前控制器中工作,但需要进一步测试。有更好的解决方案吗?

于 2013-04-25T13:17:49.563 回答