2

描述表格的图像-> http://i.stack.imgur.com/ki2YP.jpg

每个表都是一个模型。

通过 CGridView 显示的主要模型是“RegularTask”。

现在我需要它在同一行中显示“YearlyTask”中的字段。

hp_id ”和“ up_id ”在两个表中都是 FK(外键)。

我尝试像这样在 RegularTask 模型中设置关系():

'arp' => array(self::BELONGS_TO, 'YearlyTask', 'hp_id, up_id'),

然后我尝试使用“arp.is_sent”和“arp.is_reported”显示来自YearlyTask的“is_sent”和“is_reported”字段,但没有显示(甚至没有错误)。而来自 RegularTask 的数据正常显示。

我究竟做错了什么?

这是来自数据提供者的片段..

<?php
$dataProvider=new CActiveDataProvider('RegularTask', array(
    'criteria'=>array(
        'condition'=>'t.id_id=' . $model->id,
        'order'=>'t.created DESC',
        'with'=>array('arp'),
    ),
    'pagination'=>array(
        'pageSize'=>10,
    ),
));

$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider'=>$dataProvider,
    'columns'=>array(
        'comment',
        'arp.is_sent'
    ),
));
?>
4

2 回答 2

2

一个表的外键必须是链表的主键。如果你用你的结构查看 Yii 创建的 SQL 语句,你会看到类似这样的内容(简化):

SELECT `t`.*, `arp`.* FROM `RegularTask` `t` LEFT OUTER JOIN `YearlyTask` `arp` ON (`t`.`hp_id`=`arp`.`id`) AND (`t`.`up_id`=`arp`.`id`)

如您所见,它寻找的是两者RegularTaskhp_idRegularTaskup_id具有与 相同的值YearlyTaskid这是不正确的。你有几个解决方案。其中之一是在 RegularTask 中创建新列,yt_id就像YearlyTask. id在我看来,这是最好的解决方案。

否则,您可以删除表中的主键列idRegularTask制作hp_idup_id作为复杂主键。在这种情况下,您可以使用您之前尝试过的方式,但由于我不知道您的完整数据库结构,我不能保证这是一个好的解决方案。

于 2011-09-30T14:54:17.660 回答
-1

您是否尝试过使用这种风格:

$this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider'=>$dataProvider,
    'columns'=>array(
        'comment',
        array(
            'header'=>'Sent',
            'type'=>'raw',
            'value'=>'$data->arp->is_sent',
        )
    ),
));

也许不是最优雅的方式,但可能会有所帮助

于 2011-09-30T10:20:56.760 回答