我尝试使用$this>model->find()
方法获得一个数组,其中包含具有以下表单的模型的I:
Array ( [0] => 2, [1] => 3) (value are the IDs)
我尝试了$this->model->find('list')
,我认为这也会奏效,但由于一些奇怪的原因,我已经这样做了:
$this->model->find('list',array('recursive' => -1 ,'fields' => array('model.type_id'),'conditions'=>$cond));
查询结果是:
SELECT `model`.`round_id`, `model`.`type_id` FROM `database`.`model` AS `X` WHERE `X`.`Round_id` = '1'
如果对数据库进行此查询,则返回两个值,但cakephp只返回一个:
Array ( [1] => 2 )
我不知道这会不会
发布于 2013-01-25 02:18:31
我会用
$ids = $this->Model->find('list', array('fields' => array('id')));
如果您确实需要基于0的整数键,则仍然可以:
$ids = array_values($ids);
但这是不必要的,海事组织。
更新:
在您的问题更新后,您的问题本身的全部含义发生了变化:
如果只指定id,则它们的键和值都将被填充。使用'fields' => array('round_id', 'type_id')
,round_id填充键,type_id填充查找(列表)的值。
find( list )总是返回一个列表(键+值行)。如果你不想那样的话,那就用find(全部)。
https://stackoverflow.com/questions/14519660
复制