0

我有三个模型:项目、学生和投票。下面的代码就是它们之间的关系。在项目模型中:

public $hasMany = array('Student' => array(
    'className' =>'Student',
    'foreignKey'=>'project_id',
    'order' => 'Student.studentName DESC',
),
'Vote' => array(
    'className' =>'Vote',
    'foreignKey'=>'project_id',
));

在学生模型中:

public $belongsTo = array(
    'Project'=>array(
        'className'=>'Project',
        'foreignKey'=>'project_id'
));

在投票模型中:

public $belongsTo = array(
    'Project'=>array(
        'className' => 'Project',
        'foreignKey' => 'id'
));

但是,当我调用此函数时(在项目模型中):

public function getApprovedProjects(){
    $approvedProjects = $this->find('all', array('conditions'=>array(
    'Project.approved' => 1)));
    return $approvedProjects;
}

这是我得到的数据:

Array(
[0] => Array
    (
        [Project] => Array
            (
                [id] => 0
                [projectName] => MyProject
                [semester] => GAME
                [description] => Test project
                [imageLink] => 
                [approved] => 1
            )

        [Student] => Array
            (
            )

        [Vote] => Array
            (
            )

    )

[1] => Array
    (
        [Project] => Array
            (
                [id] => 1
                [projectName] => CRIA STUFF
                [semester] => CRIA
                [description] => Cria project
                [imageLink] => 
                [approved] => 1
            )

        [Student] => Array
            (
            )

        [Vote] => Array
            (
            )

    )
)

它没有找到与该项目相关的任何学生或选票,即使它们存在并且我认为它应该存在。知道发生了什么吗?

4

1 回答 1

0

好的伙计们,我解决了这个问题。

事实证明,Cake 不喜欢与 id 为 0 的数据进行关联。我的所有其他提取都有效,并且一旦我将表中的所有数据更改为 id 不为 0,我的发现奏效了。

因此,以后不要向表中添加 id 为 0 的条目。从 1 开始。

于 2013-06-17T17:35:08.093 回答