我想创建这样的表Yii Booster Gridview table
这是我在控制器中的代码:

$rawData=Jobspecs::model()->with('customer')->findAll();
$gridDataProvider=new CArrayDataProvider($rawData, array(
    'id'=>'user',

    'sort'=>array(
        'attributes'=>array(
             'id', 'customer',
            ),

        ),

    ));
$gridColumns = array(

    array('name'=>'id', 'header'=>'Js No.', 'htmlOptions'=>array('style'=>'width: 60px')),

    array('name'=>'WHAT TO PUT HERE TO SHOW CUSTOMER NAME', 'header'=>'Customer Name'),

    array(

        'htmlOptions' => array('nowrap'=>'nowrap'),

        'class'=>'booster.widgets.TbButtonColumn',

        'viewButtonUrl'=>null,

    )

    );

在我的模型sapcusters中:
return array(
            'customer'=>array(self::BELONGS_TO, 'Sapcustomers', 'customer'),
        );

作业规格模型
return array(
            'cardname'=>array( self::HAS_MANY, 'Jobspecs', 'customer' ),
        );

我的观点
<?php
        $this->widget(
            'booster.widgets.TbGridView',
            array(
                'type' => 'bordered',
                'dataProvider' => $gridDataProvider,
                'template' => "{items}",
                'columns' => $gridColumns,
            )
        );
?>

如您所见,我加入了sapcusters和jobspecs表。我的问题是,我需要在$gridcolums上输入什么代码来显示sapcustomer表中的客户名称数据。谢谢你的帮助

最佳答案

我认为这应该对你有用:

$gridColumns = array(
    [...]

    array(
         'name'=>'customer',
         'value'=>'$data->customer->name',
         'header'=>'Customer Name'
    ),
);

解释
$data表示实际行中的Jobspecs-model。然后访问相关的customer和他的name

关于php - Yii Booster Gridview表联接表,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/27976536/

10-12 14:40