问题描述
|
如何在Yii中建立具有关系的固定装置?例如,对于可以发表评论的帖子,我该如何参考灯具中的帖子ID来创建评论?
立柱夹具:
return array(
\'post1\'=>array(
\'title\'=>\'My title\',\'body\'=>\'My text\',),...
评论夹具:
return array(
\'comment1\'=>array(
\'text\'=>\'Comment text...\',\'post_id\'=> ???
),
解决方法
我不知道是否有一种动态的方法来执行此操作,但是以下方法应该起作用:
立柱夹具:
return array(
\'post1\' => array(
\'id\' => 1
\'title\' => \'My title\',\'body\' => \'My text\',),
评论夹具:
return array(
\'comment1\' => array(
\'text\' => \'Comment text...\',\'post_id\' => 1
),
, 据我了解,您可以使用init脚本代替经典的固定装置。 Yii文档显示:
我们也可能不喜欢使用默认方式重置
表格,即将其截断并将其与灯具数据一起插入。如果
在这种情况下,我们可以为
特定的夹具文件。该脚本必须命名为表名
后缀.init.php。例如,用于
Post表将是Post.init.php。当CDbFixtureManager看到
此脚本,它将执行此脚本,而不是使用默认脚本
重置表的方法。
因此,在您的情况下,您将拥有protected/tests/fixtures/Comment.init.php
,而不是拥有protected/tests/fixtures/Comment.php
:
// the $this variable refers to the CBdFixtureManager instance
$this->truncateTable($tableName);
$post = $this->getRecord(\'Post\',\'post1\'); // get dependent fixture
// define new fixture
$commentAttributes = array(
\'text\' => \'Comment text...\',\'post_id\' => $post->id
);
$comment = new Comment;
$comment->setAttributes($commentAttributes);
if(!$comment->save()) throw new CException(\'Unable to save fixture\');
// add new row primary key
$pk = Comment::model()->getTableSchema()->primaryKey;
if(is_string($pk))
$commentAttributes[$pk] = $comment->$pk;
elseif(is_array($pk))
foreach($pk as $key)
$commentAttributes[$key] = $comment->$key;
$this->_rows[\'Comment\'][\'comment1\'] = $commentAttributes;
$this->_records[\'Comment\'][\'comment1\'] = \'Comment\';
尽管我意识到这是一个很晚的答复,但是应该可以解决您的问题。自从来到这里进行谷歌搜索以来,我希望可以帮助需要此信息的其他人。
, 我知道已经回答了,但是我认为这是一个更好的答案。
是的,您可以将动态字段用于关系:
立柱夹具:
return array(
\'post1\' => array(
\'title\' => \'My title\',\'post_id\' => $this->getRecord(\'post\',\'post1\')->id
),
PostTest.php
public $fixtures=array(
\'post\'=>\'Post\',...
);
Yii文档CDbFixtureManager