多表关联显示在CGridView中

本文介绍了一个简单的数据库关联查询示例,展示了如何通过定义模型间的关系实现跨表查询,并在显示层展示查询结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我有2个表 :url_info ; category
url_info 字段: id,cid ,title


category字段:id ,name
其中url_info.cid=category.id
目的:就是关联2个表查询出 这样的结构 url_info.id category.name title

其中url_info model中的关系如下写:

/**

* @return array relational rules.





*/
public function relations()
{
// NOTE: you may need to adjust the relation name and the related
// class name for the relations automatically generated below.
return array(
'category'=>array(self::BELONGS_TO, 'category', 'cid'),
);
}

控制层:
/**
* Manages all models.
*/
public function actionAdmin()
{
$dataProvider=new CActiveDataProvider('url_info', array(
'criteria'=>array(
'condition'=>'cid=category.id',
'with'=>array('category'),
'order'=>'cid desc',
),
'pagination'=>array(
'pageSize'=>self::PAGE_SIZE,
),
));

$this->render('admin',array(
'dataProvider'=>$dataProvider,
));
}

显示层:
$this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$dataProvider,
'columns'=>array(
'id',
'category.name',
'title',
array(
'class'=>'CButtonColumn',
),
),

sql 语句:
mysql> select url_info.id,cid,category_name from url_info,category where url_inf
o.cid=category.id;>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值