gpt4 book ai didi

php - CakePHP:如果我在查找中组合 'fields' 和 'contain',我得不到想要的结果。谁能解释为什么?

转载 作者:可可西里 更新时间:2023-11-01 00:14:32 26 4
gpt4 key购买 nike

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

如果我这样做:

$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% 确定这是否是预期的行为,但您必须在 fields 配置中包含 PreviewImage 外键字段才能使其正常工作:

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

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

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

所以这可能是一些功能请求。就我个人而言,我希望这会自动发生。

关于php - CakePHP:如果我在查找中组合 'fields' 和 'contain',我得不到想要的结果。谁能解释为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19276240/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com