我有一个主模型,还有一个孩子模型。子模型有一个外键,它按照cakephp命名约定链接到主模型id。子模型定义主模型中记录的名称/描述。
我正在尝试用这些值(id和name)填充视图中的下拉列表框。但是Cakephp find('list')通常只从一个模型获取信息。
我怎么做才能让我的find('list')检索2个字段,比如:
- child.master_id
- child.name或
- master.id
- child.name (where child.master_id = master.id).谢谢!
发布于 2014-04-28 20:03:05
要更改find('list', $params)的键或值的字段,可以提交一个包含键fields和要用作第二个参数的字段名称的数组。
在您的示例中,以下代码将返回数组的键更改为child.master_id,值更改为child.name
$childs = $this->Child->find('list', array(
'fields' => array('Child.master_id', 'Child.name')
));有关查找类型'list'的更多信息,请阅读cookbook。
发布于 2014-04-28 21:23:50
只需定义字段
对于问题中给出的示例,您只需在find调用中指定两个字段:
$result = $Child->find('list', array(
'fields' => array('master_id', 'name')
));当向find list传递两个字段时,它们被用作结果数组的键和值。
如果您确实需要从不同的模型返回字段,则需要告诉cake进行连接。最简单的方法是指定递归值0(假设关系子主belongsTo已正确设置):
$sameResult = $Child->find('list', array(
'fields' => array('Master.id', 'Child.name'),
'recursive' => 0
));请注意,在此场景中,可能需要在字段列表中指定模型名称,以避免生成不明确的sql。
https://stackoverflow.com/questions/23336434
复制相似问题