ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

CakePHP:如果我在find中组合’fields’和’contains’,我就得不到想要的结果了.有谁能解释为什么?

2019-07-25 12:30:50  阅读:185  来源: 互联网

标签:cakephp-2-0 containable php cakephp


我有以下情况:作品有一个Image属于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'
    )
)

)

我不明白为什么,你有什么想法吗?

解决方法:

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

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

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

When using ‘fields’ and ‘contain’ options – be careful to include all foreign keys that your query directly or indirectly requires.

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

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

标签:cakephp-2-0,containable,php,cakephp
来源: https://codeday.me/bug/20190725/1532840.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有