Mar*_*tin 0 php activerecord non-relational-database yii
我刚刚开始学习使用yii,并且已经设法做了一些基本的东西.
假设我有两个简单的表:"用户"和"项目",其中关系是1到多(一个用户可以有很多项目)
我使用GII生成了CRUD,但是在"创建/编辑用户页面"中,这不提供下拉列表,而只提供我需要输入用户ID的文本字段.
在编辑项目时,我想有一个下拉列表,我可以在其中选择一个用户(因此该元素应该显示一个用户名列表).
我假设GII无法为此生成控制器和查看代码
这样做的最佳做法是什么?
我已按照http://www.yiiframework.com/doc/guide/1.1/en/database.arr中的说明声明了这些关系
public function relations()
{
return array(
'projects_rel'=>array(self::BELONGS_TO, 'Users', 'user_id'),
);
}
Run Code Online (Sandbox Code Playgroud)
和
public function relations()
{
return array(
'users_rel'=>array(self::HAS_MANY, 'Projects', 'project_id'),
);
}
Run Code Online (Sandbox Code Playgroud)
找到生成用户列表的示例代码
<?php
$form = $this->beginWidget('CActiveForm', array(
'id' => 'project-form',
'enableAjaxValidation' => true,
));
Run Code Online (Sandbox Code Playgroud)
?>
<?php echo $form->dropDownList($model, 'user_id',
CHtml::listData(Projects::model()->with('projects_rel')->findAll(), 'id', 'username'),
array('style'=>'width:150px;')
); ?>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6570 次 |
| 最近记录: |