我有下表。
User:
---------
id<br>
firstName
Project:
---------
id<br>
Name
StaffingManager
---------------
id<br>
User_id(FK)<br>
Total_Staff<br>
StaffingProjectMonth
-----------------------
id<br>
Project_id(FK)<br>
StaffingManager_id(FK)<br>
我想定义 StaffingProjectMonth 模型中的关系
这是 YII 使用 gii 定义的默认关系
public function relations()
{
return array(
'project' => array(self::BELONGS_TO, 'Project', 'Project_id'),
'staffingManager' => array(self::BELONGS_TO, 'StaffingManager', 'StaffingManager_id'),
);
}
我能够获取项目名称并按项目名称进行搜索。
我想获取 UserfirstName 并据此进行搜索。
我这样定义了关系。
return array(
'project' => array(self::BELONGS_TO, 'Project', 'Project_id'),
'staffingmanager' => array(self::BELONGS_TO, 'StaffingManager', 'StaffingManager_id'),
'user'=> array(self::HAS_MANY,'User',array('User_id'=>'id'),'through'=>'staffingmanager' ),
);
在搜索方法中我这样做了:
$criteria->with = array('project','user');
//$criteria->compare('id',$this->id);
$criteria->compare('Name',$this->Project_id,true);
$criteria->compare('firstName',$this->StaffingManager_id,true);
在 View 中:
$this->widget('zii.widgets.grid.CGridView', array(
'id'=>'staffing-project-month-grid',
'dataProvider'=>$model->search(),
'filter'=>$model,
'columns'=>array(
// 'id',
array('name'=>'Project_id','header'=>'Project','value'=>'$data->project->Name',),
array('name'=>'StaffingManager_id','header'=>'User','value'=>'$data->staffingmanager->user->firstName',),
..............
只有按项目名称搜索才有效。能够访问 UserfirstName,但无法按 firstName 进行搜索。定义关系时有些错误。
感谢任何帮助。谢谢。
最佳答案
我推荐以下excellent wiki article by redguy ,描述了如何通过相关模型属性进行搜索:
按照本文的方法:
您应该在模型中声明两个新变量:
public $project_name;
public $staffingmanager_firstname;
您应该在 rules()
方法中将这些新变量声明为安全搜索:
array( 'project_name,staffingmanager_firstname,...', 'safe', 'on'=>'search' ),
您的 search()
方法标准应如下所示:
$criteria->compare('project.Name',$this->project_name,true);
$criteria->compare('user.firstName',$this->staffingmanager_firstname,true);
在您的 View 文件中,“列”应该是:
array('name'=>'project_name','header'=>'Project','value'=>'$data->project->Name',),
array('name'=>'staffingmanager_firstname','header'=>'User','value'=>'$data->user->firstName',),
希望这有帮助。
致以诚挚的问候...
关于yii 'through' 关系搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10246781/