讲师教授模块,有些是模块组织者。在这里,我将获取讲师讲授的模块:
array(
(int) 0 => array(
'organiser' => '1',
'module_id' => '2',
'lecturer_id' => '1',
'Module' => array(
'code' => 'MOD2',
'name' => 'Z Name'
)
),
(int) 1 => array(
'organiser' => '1',
'module_id' => '1',
'lecturer_id' => '1',
'Module' => array(
'code' => 'MOD1',
'name' => 'Module Name'
)
)
)
如何按模块名称对其进行排序?我使用了hasMany through关系,因为连接表中需要额外的数据(例如组织者)。这是我用来在他们的个人资料中包含讲师数据的方法。注释掉的行不起作用。
public function get($id = null) {
$this->contain(
array(
'User',
'County.name',
'School' => array(
'fields' => array('code', 'name')
),
'ModuleStaff' => array(
'fields' => array('organiser'),
'Module' => array(
'fields' => array('code', 'name'),
),
// 'order' => 'Module.name',
)
)
);
return $this->findByUserId($id);
}
以下是我与ModuleStaff连接类的关系
public $belongsTo = array(
'Lecturer' => array(
'className' => 'Lecturer',
'foreignKey' => 'lecturer_id',
'conditions' => '',
'fields' => '',
'order' => ''
),
'Module' => array(
'className' => 'Module',
'foreignKey' => 'module_id',
'conditions' => '',
'fields' => '',
'order' => ''
)
);
为Module的订单值添加名称不起作用,因为每个ModuleStaff只链接到一个Module,我需要通过其子类中的值对actuall ModuleStaff对象进行排序。
答案 0 :(得分:0)
您是否尝试将'order' => 'Module.name'
元素放入Module
数组?像这样:
'ModuleStaff' => array(
'fields' => array('organiser'),
'Module' => array(
'fields' => array('code', 'name'),
'order' => array('Module.name')
)
)