首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Cakephp find(‘displayField’)从子模型中获取列表

Cakephp find(‘displayField’)从子模型中获取列表
EN

Stack Overflow用户
提问于 2014-04-28 16:44:52
回答 2查看 696关注 0票数 1

我有一个主模型,还有一个孩子模型。子模型有一个外键,它按照cakephp命名约定链接到主模型id。子模型定义主模型中记录的名称/描述。

我正在尝试用这些值(id和name)填充视图中的下拉列表框。但是Cakephp find('list')通常只从一个模型获取信息。

我怎么做才能让我的find('list')检索2个字段,比如:

代码语言:javascript
复制
- child.master_id
- child.name

代码语言:javascript
复制
- master.id
- child.name (where child.master_id = master.id).

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2014-04-28 20:03:05

要更改find('list', $params)的键或值的字段,可以提交一个包含键fields和要用作第二个参数的字段名称的数组。

在您的示例中,以下代码将返回数组的键更改为child.master_id,值更改为child.name

代码语言:javascript
复制
$childs = $this->Child->find('list', array(
    'fields' => array('Child.master_id', 'Child.name')
));

有关查找类型'list'的更多信息,请阅读cookbook

票数 1
EN

Stack Overflow用户

发布于 2014-04-28 21:23:50

只需定义字段

对于问题中给出的示例,您只需在find调用中指定两个字段:

代码语言:javascript
复制
$result = $Child->find('list', array(
    'fields' => array('master_id', 'name')
));

当向find list传递两个字段时,它们被用作结果数组的键和值。

如果您确实需要从不同的模型返回字段,则需要告诉cake进行连接。最简单的方法是指定递归值0(假设关系子主belongsTo已正确设置):

代码语言:javascript
复制
$sameResult = $Child->find('list', array(
    'fields' => array('Master.id', 'Child.name'),
    'recursive' => 0
));

请注意,在此场景中,可能需要在字段列表中指定模型名称,以避免生成不明确的sql。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23336434

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档