Yii Booster Gridview表连接表

时间:2015-01-16 02:47:14

标签: php yii

我想创建一个像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,

    )

    );

在我的模型sapcustomers中:

return array(
            'customer'=>array(self::BELONGS_TO, 'Sapcustomers', 'customer'),
        );

jobspecs模型

return array(
            'cardname'=>array( self::HAS_MANY, 'Jobspecs', 'customer' ),
        );

我的观点

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

你可以看到我加入了sapcustomers和jobspecs表。我的问题是我需要在$gridcolums上放置哪些代码来显示表sapcustomer中的客户名称数据。谢谢你的帮助

1 个答案:

答案 0 :(得分:1)

我认为这应该适合你:

$gridColumns = array(
    [...]

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

<强>解释

$data代表实际行中的Jobspecs-model。然后,您可以访问相关的customer和他的name