yii 'through' 关系搜索

标签 yii

我有下表。

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/

相关文章:

php - 在 Yii 中返回 CActiveDataProvider

php - Yii框架中定义的Gii的路由在哪里?

javascript - Fancybox 点击与 Yii CGridView 中的元素绑定(bind)和 ajax 分页

css - Yii:在模块级别集成 CSS 文件

php - 将 MySQL 查询的结果动态显示到 HTML 页面中

php - 具有复合主键的 Yii 模型

database - 来自 Digital Ocean Instance 的远程 Postgres 数据库 Heroku 连接速度很慢

php - 在禁用 JS 的浏览器中使用 YII 小部件

mysql - yii 1 关系在 CGridView 中不起作用

javascript - Ajax 提交错误