3

我有以下情况:作品有一个属于 ImageGroup 的图像。

如果我这样做:

$works = $this->Work->find('all', array(
    'contain' => array(
        'PreviewImage' => array(
            'fields' => array('PreviewImage.id', 'PreviewImage.filename', 'PreviewImage.alt'),
            'ImageGroup' => array(
                'fields' => array('ImageGroup.id')
            )
        )
    )
));

我会得到这个:

array(
(int) 0 => array(
    'Work' => array(
        'id' => '1',
        'title_us' => 'Work Title',
        'title_de' => 'Arbeit Titel',
        'alias' => 'work-title',
        'pdf_id' => '1',
        'date' => '2013-10-08 10:36:00',
        'title_graphic_us_id' => '1',
        'title_graphic_de_id' => '2',
        'body_us' => 'English Content',
        'body_de' => 'Deutscher Inhalt',
        'preview_image_id' => '3',
        'preview_us' => 'English Preview Text',
        'preview_de' => 'Deutscher Vorschau Text',
        'work_layout_id' => '2',
        'state_id' => '1'
    ),
    'PreviewImage' => array(
        'id' => '3',
        'filename' => 'preview_image.png',
        'alt' => 'Preview Image',
        'image_group_id' => '2',
        'ImageGroup' => array(
            'id' => '2'
        )
    )
)

)

但是,如果我试图通过以下方式减少工作领域:

$works = $this->Work->find('all', array(
    'fields' => array(
        'Work.id'
    ),
    'contain' => array(
        'PreviewImage' => array(
            'fields' => array('PreviewImage.id', 'PreviewImage.filename', 'PreviewImage.alt'),
            'ImageGroup' => array(
                'fields' => array('ImageGroup.id')
            )
        )
    )
));

我突然不再在 PreviewImage 中获得 ImageGroup,请参见此处:

array(
(int) 0 => array(
    'Work' => array(
        'id' => '1'
    ),
    'PreviewImage' => array(
        'id' => '3',
        'filename' => 'preview_image.png',
        'alt' => 'Preview Image',
        'image_group_id' => '2'
    )
)

)

我不明白为什么,你知道吗?

4

1 回答 1

9

我不能 100% 确定这是否是预期的行为,但您必须PreviewImage在配置中包含外键字段fields才能使其正常工作:

$works = $this->Work->find('all', array(
    'fields' => array(
        'Work.id',
        'Work.preview_image_id'
    ),
    'contain' => array(
        ...
    )
));

文档提到确保在使用fields选项时包含所有必要的外键contain

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

http://book.cakephp.org/2.0/en/core-libraries/behaviors/containable.html

所以这可能是功能请求的东西。就我个人而言,我预计这会自动发生。

于 2013-10-09T16:07:35.073 回答