Yii Framework:在数据提供者中加入表(或其他SQL)?

时间:2014-08-07 07:13:07

标签: php yii

背景

我使用了Gii Crud Generator和我的"类别"模型,我想修改管理表单。

我查看" protected / views / Category / admin.php,

我发现表格是由小部件呈现的(' zii.widgets.grid.CGridView'), 并使用数据提供者为其提供数据。

我想我可以找到一些在数据提供程序中输入SQL查询的位置,但我不了解它是如何工作的。

这些是模型 - > relations()中的代码,但我不知道下一步该做什么。

public function relations(){
    return array(
        'cateLang' => array(self::HAS_MANY, 'CategoryLang', 'cate_id')
    );
}

生成数据提供者的地方:

public function search(){

    $criteria=new CDbCriteria;

    $criteria->compare('id',$this->id);
    $criteria->compare('status',$this->status,true);
    $criteria->compare('createDate',$this->createDate,true);
    $criteria->compare('updateDate',$this->updateDate,true);
    $criteria->compare('remark',$this->remark,true);

    return new CActiveDataProvider($this->with('cateLang'), array(
        'criteria'=>$criteria,
    ));
}

:定位

我想在" protected / views / Category / admin.php,

的表格中再添加两列

将显示法国标题&行的英文标题。

要在SQL中获取数据,它将是:

SELECT 
    cate.id,
    lang1.name as "FrenchTitle",
    lang2.name as "EnglishTitle",
    cate.updateDate,
    cate.createDate,
    cate.remark 
FROM `category` cate
LEFT JOIN `categorylang` lang1
    ON `lang1`.`cate_id` = `cate`.id 
    AND `lang1`.`lang_id`= 1
LEFT JOIN `categorylang` lang2
    ON `lang2`.`cate_id` = `cate`.id 
    AND `lang2`.`lang_id`= 2
WHERE cate.status = 'live'

如果我可以使用数据提供程序,CGridView参数可能是这样的:

$this->widget('zii.widgets.grid.CGridView', array(
    'id'=>'category-grid',
    'dataProvider'=>$model->search(),
    'filter'=>$model,
    'columns'=>array(
        'id',
        'FrenchTitle',
        'EnglishTitle',
        'createDate',
        'updateDate',
        'remark',
        array(
            'class'=>'CButtonColumn',
        ),
    ),
)); 

1 个答案:

答案 0 :(得分:0)

您可以尝试以下方法:

public function search(){

    $criteria=new CDbCriteria;

    $criteria->compare('id',$this->id);
    $criteria->compare('status',$this->status,true);
    $criteria->compare('createDate',$this->createDate,true);
    $criteria->compare('updateDate',$this->updateDate,true);
    $criteria->compare('remark',$this->remark,true);
    $criteria->with = array('cateLang' => array(
        'condition' => 'cateLang.id = 1 OR cateLang.id = 2',
        'order' => 'cateLang.id ASC'
    ));

    return new CActiveDataProvider($this, array(
        'criteria'=>$criteria,
    ));

}

$this->widget('zii.widgets.grid.CGridView', array(
    'id'=>'category-grid',
    'dataProvider'=>$model->search(),
    'filter'=>$model,
    'columns'=>array(
        'id',
        array(
            'name' => 'FrenchTitle'
            'value' => '(isset($data->cateLang[0])) ? $data->cateLang[0]->name : "no Title"',
        ),
        array(
            'name' => 'EnglishTitle'
            'value' => '(isset($data->cateLang[1])) ? $data->cateLang[1]->name : "no Title"',
        ),
        'createDate',
        'updateDate',
        'remark',
        array(
            'class'=>'CButtonColumn',
        ),
    ),
)); 

在搜索中,我指定只需要id为1或2的cateLang对象,然后在cgridview中显示关系对象。

相关问题