2

我有以下协会

后->小学->中学

$results = $this->Post->find('all', array(
    'conditions' => array(
        'Post.post_id =' => 2,
        'Primary.secondary_id !=' => null
    ),
    'contain' => array(
        'Primary' => array(
            'Secondary' => array(
                'conditions' => array('Secondary.short_code =' => 'code')
            )
        )
    )
));

返回这个。

Array
(
    [0] => Array
        (
            [Post] => Array
                (
                    [id] => 2
                    [created] => 2012-10-29 09:48:29
                    [modified] => 2012-10-29 09:48:29
                )

            [Primary] => Array
                (
                    [id] => 3
                    [secondary_id] => 6
                    [Secondary] => Array
                        (
                            [id] => 6
                            [short_code] => code
                            [created] => 2012-10-31 11:19:56
                            [modified] => 2012-10-31 11:20:03
                        )

                )

        )

但是当我改变

'conditions' => array('Secondary.short_code =' => 'code')

'conditions' => array('Secondary.short_code !=' => 'code')

当我不想要它时,它仍然返回主记录。

Array
(
    [0] => Array
        (
            [Post] => Array
                (
                    [id] => 2
                    [created] => 2012-10-29 09:48:29
                    [modified] => 2012-10-29 09:48:29
                )

            [Primary] => Array
                (
                    [id] => 3
                    [secondary_id] => 6
                    [Secondary] => Array
                        (
                        )

                )

        )
4

1 回答 1

5

很难确切知道您希望达到什么目标,但我认为这听起来像是您试图根据“次要”模型的条件来限制“主要”结果。

如果是这种情况,您将需要使用joins()而不是contain().

原因:当您使用CakePHP 的 Containable Behavior时,它实际上会执行单独的查询,然后在将数据返回给您之前组合结果。这样做在很多方面都很棒,但它不允许您根据针对其子项的条件来限制父项结果。

为此,只需使用joins()。(创建 MySQL JOIN 的 CakePHP 语法)

于 2012-10-31T18:52:46.337 回答