比如:还是那2张表
url_info ; category url_info 字段: id,cid ,title,url category字段:id ,name
其中url_info.cid=category.id
目的:根据category的name 查出URL_INFO中相对应的URL
比如我有一个有 名字叫:魔兽世界 (也就是:category.name=魔兽世界),我想找出和魔兽世界相关系的网站,比如它的官网地址 下载地址等。
YII 框架其实很好了用的。只要你写出2个表的关系:
/** * @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'), ); }
显示层:
$this->widget('zii.widgets.grid.CGridView', array( 'dataProvider'=>$dataProvider, 'columns'=>array( 'id', array( 'class'=>'CLinkColumn', 'header'=>'游戏类别名称',//显示表名称 'labelExpression'=>'$data->category_name',//显示名称 'urlExpression'=>'Yii::app()->createUrl("url_info",array("cid"=>$data->id))',//显示URL //'linkHtmlOptions'=>array('title'=>'See all entries with this last name') ), 'category_style', 'sort_num', array( 'class'=>'CButtonColumn', ), ),
其中我用到了YII框架中自带的CLinkColumn属性。
还有种办法:
$this->widget('zii.widgets.grid.CGridView', array( 'dataProvider'=>$dataProvider, 'columns'=>array( 'id', array( 'name'=>'category_name', 'value'=>'CHtml::link($data->category_name,$url)',//名称和URL ), 'category_style', 'sort_num', array( 'class'=>'CButtonColumn', ), ),
这种方法用的是CHtml::link()
然后只要在url_info的控制层中写出
$dataProvider=new CActiveDataProvider('url_info', array( 'criteria'=>array( 'condition'=>'cid=:id', 'params'=>array(':cid'=>$_GET['cid']), 'with'=>array('category'), 'order'=>'cid desc', ), 'pagination'=>array( 'pageSize'=>self::PAGE_SIZE, ), ));
就好了!