3

这是我的模型:

class Question extends AppModel {


public $hasMany = array(
    'CaseQuestions' => array('className'=>'Question', 'foreignKey'=>'parent_id')
);

public $hasOne = array(
    'CaseStudy' => array('className'=>'Question', 'foreignKey'=>'parent_id')
);

这是我的控制器中的操作:

public function admin_delete_case_question($question_id) {
        $this->Question->Behaviors->load('Containable');
        $this->Question->contain( array('CaseStudy'));
        $question = $this->Question->findById($question_id );
        debug($question); 
        exit;

上面的调试返回如下内容:

array(
    'Question' => array(
        'id' => '78',
        'nickname' => '',
        'content' => 'sdgsdfgs',
        'type' => 'CQ',
        'option1' => 'sdfgsdfg',
        'option2' => '',
        'option3' => '',
        'option4' => '',
        'time' => '-1',
        'difficulty' => '0.0000',
        'slope' => '0.0000',
        'chance' => '0',
        'experiment' => false,
        'created' => '2013-05-02 16:30:29',
        'modified' => '2013-05-02 16:30:29',
        'status' => null,
        'perm_id' => '76',
        'notes' => null,
        'is_deleted' => false,
        'answer_id' => '0',
        'parent_id' => '77',
        'order' => null
    ),
    'CaseStudy' => array(
        'id' => null,
        'nickname' => null,
        'content' => null,
        'type' => null,
        'option1' => null,
        'option2' => null,
        'option3' => null,
        'option4' => null,
        'time' => null,
        'difficulty' => null,
        'slope' => null,
        'chance' => null,
        'experiment' => null,
        'created' => null,
        'modified' => null,
        'status' => null,
        'perm_id' => null,
        'notes' => null,
        'is_deleted' => null,
        'answer_id' => null,
        'parent_id' => null,
        'order' => null
    )
)

我不明白为什么 CaseStudy 数组全部为 NULL,因为当我查看数据库中的该记录(id 77)时,所有数据都是正确的。我究竟做错了什么?

4

2 回答 2

3

在您的示例中...问题有一个案例研究;这意味着问题是父母。

根据您的数据,您的问题有一个 parent_id,所以我假设您实际上的意思是 CaseStudy 是父母,问题是孩子。看起来您的关联实际上是倒退的(通常父级不会有 parent_id)。

用 belongsTo 替换你的 hasOne 关联:

public $belongsTo = array(
      'CaseStudy' => array('className'=>'Question', 'foreignKey'=>'parent_id')
);

这将确保 CaseStudy 是父级,而 Question 是子级。

按照目前的设置方式,CakePHP 正在尝试寻找一个具有与您的 Question.id 相同的 parent_id 的 CaseStudy;因为您的 DB CakePHP 中没有任何类似的数据,所以什么也没找到并返回空值。实际上,CaseStudy 实际上是父级,并且 Question 的 parent_id 等于 CaseStudy.id

于 2013-05-03T01:25:44.453 回答
2

试试这个:

//Question model
public $actsAs = array('Containable'); //personally, I put this in my AppModel

//QuestionsController
$question = $this->Question->find('first', array(
   'conditions' => array(
        'id' => $question_id
    ),
    'contain' => array(
        'CaseStudy'
    )
));
于 2013-05-02T20:57:00.587 回答