public function searchWithRelated() {
$criteria = new CDbCriteria;
$criteria->together = true; //without this you wont be able to search the second table's data
$criteria->with = array('mySecondTable');
$criteria->compare('id', $this->id, true);
$criteria->compare('mySecondTable.column', $this->mySecondTable_column, true);
return new CActiveDataProvider($this, array(
'criteria' => $criteria,
'sort'=>array(
'defaultOrder'=>'t.create_time DESC',
),
'pagination' => array(
'pageSize' => 100,
),
));
}php
高级应用程序模板
这个模板用在大型的团队开发项目中,并且后台从前台独立分离出来以便于部署在多个服务器中。因为YIi2.0的一些新的特性,这个程序模板的功能要更深一点。提供了基本的数据库的支持,注册、密码找回等功
能够经过Composer来安装
若是没有安装Composer,先安装html
curl -s http://getcomposer.org/installer | php
而后用以下命令来获取前端
php composer.phar create-project --prefer-dist --stability=dev yiisoft/yii2-app-advanced /path/to/yii-application
也能够直接下载压缩文件:Yii 2 with advanced application template(beta)
https://github.com/yiisoft/yii2/ ... -app-2.0.0-beta.tgz
开始
安装完成后,须要对其进行初始化操做。node
php /path/to/yii-application/init
yii migrate
目录结构
在根目录下面有这几个子目录git
根目录下面还有包含一些文件github
系统定义的路径别名web
应用程序
这个模板包含三个应用程序,前台、后台和控制台。前台一般来讲就是展示给终端用户的,也就是项目自己。后台就是管理员控制面板,包含有分析以及相似的功能等。控制台主要用来作一些定时任务和一些简单的服务器的管理,另外也能够用来部署应用程序、数据库的迁移、资源的管理等。
common 目录提供一些公共的文件,可用于多个应用程序,例如User模型。
前台和后台都是web应用程序,他们都包含一个web目录,也就是web的根目录,在部署服务器的时候就得要指向这个目录。
每一个应用程序都有他们本身的命名空间以及对应的别名。同理,common也有本身的命名空间和对应的别名。
配置和开发环境
在日常的开发中,直接设置配置文件会有多个问题数据库
为了解决这些问题,Yii引入了一个很是简单的环境的概念。每一个环境由环境目录下的一组文件的集合来表示。init命令用于不一样环境之间切换。它只是复制从环境目录中全部应用程序的根目录。
一般环境包含应用程序引导文件如index.php和以-local.php后缀的配置文件。这些已经添加到.gitignore中,因此不会再添加到源码仓库中。
为了不重复的配置文件相互覆盖。例如,前台应用程序按照如下顺序来读取配置:json
参数文件按如下顺序读取bootstrap
后面读取的文件配置会覆盖前面的配置
整个的流程图形以下
配置 Composer
应用程序安装完成后就能够设置要目录下面的composer.json
首先,修改一些基本信息。例如名称,描述,关键词,主页等等。
你还能够根据你的须要添加更多的应用程序。这些包都是来自packagist.org,可免费的浏览全部的代码。
修改完composer.json以后 就能够运行
php composer.phar update --prefer-dist
,等下载并安装完成后就能够开始使用了。自动加载的类将会自动处理。
建立从后端到前端的连接
一般状况下须要从后端应用程序链接到前端应用程序。由于前端应用程序可能包含本身的URL管理规则,因此须要再添加一个不一样名字的后台的URL管理规则。
以后,就能够像这样来使用前台的url
Reference: Learn Yii Framework online – CGridView filter with relational field
Model:
1. 添加filter用的属性
var $a = “”;
var $b = “”;
2. 修改rules方法中的配置
array(‘……., a, b’, ‘safe’, ‘on’=>’search’);
3. 注意relations方法
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(
‘xxx‘ => array(self::HAS_ONE, ‘xxxModel’, array(‘…’ => ‘….’)),
);
}
4. 修改search()方法添加行
$criteria->compare(‘xxx.ax‘,$this->a);
$criteria->compare(‘xxx.bx‘,$this->b);
View
1. ‘dataProvider’=>$model->with(“xxx“)->search(),
2. 列展现修改
array(
‘name’ => ‘a‘,
‘value’ => ‘$data->xxx->ax‘,
‘filter’ => array(select的下来菜单数组),
),
array(
‘name’ => ‘b‘,
‘value’ => ‘$data->xxx->bx‘,
‘filter’ => array(1 => “Set”, 0 => ‘Not Set’),
),
代码提示:
1. 添加的两个属性仅仅用于记录页面的搜索条件
2. search方法中的CDbCriteria搜索方法没有任何变化,请学习如何使用关联搜索
$criteria = new CDbCriteria;
//select
$criteria->select = '*';//默认*
$criteria->select = 'id,name';//指定的字段
$criteria->select = 't.*,t.id,t.name';//链接查询时,第一个表as t,因此用t.*
$criteria->distinct = FALSE; //是否惟一查询
//join
$criteria->join = 'left join table2 t2 on(t.id=t2.tid)'; //链接表
$criteria->with = 'xxx'; //调用relations
//where 查询数字字段
$criteria->addCondition("id=1"); //查询条件,即where id = 1
$criteria->addBetweenCondition('id', 1, 4);//between 1 and 4
$criteria->addInCondition('id', array(1,2,3,4,5)); //表明where id IN (1,23,,4,5,);
$criteria->addNotInCondition('id', array(1,2,3,4,5));//与上面正好相法,是NOT IN
//where 查询字符串字段
$criteria->addSearchCondition('name', '分类');//搜索条件,其实表明了。。where name like '%分类%'
//where 查询日期字段
$criteria->addCondition("create_time>'2012-11-29 00:00:00'");
$criteria->addCondition("create_time<'2012-11-30 00:00:00'");
//where and or
$criteria->addCondition('id=1','OR');//这是OR条件,多个条件的时候,该条件是OR而非AND
//这个方法比较特殊,他会根据你的参数自动处理成addCondition或者addInCondition,
//即若是第二个参数是数组就会调用addInCondition
$criteria->compare('id', 1);
/** * 传递参数 */
$criteria->addCondition("id = :id");
$criteria->params[':id']=1;
//order
$criteria->order = 'xxx DESC,XXX ASC' ;//排序条件
//group
$criteria->group = 'group 条件';
$criteria->having = 'having 条件 ';
//limit
$criteria->limit = 10; //取1条数据,若是小于0,则不做处理
$criteria->offset = 1; //两条合并起来,则表示 limit 10 offset 1,或者表明了。limit 1,10
<?php $this->widget('zii.widgets.grid.CGridView', array( 'id'=>'chapter-grid', 'dataProvider'=>$model->search(), //数据结果集 'filter'=>$model, 'columns'=>array( 'id', //锚点<a href="http://www.gulianqiang.com/"></a> array( 'name'=>'name', 'type'=>'raw', 'value'=>'CHtml::link($data->name,"/book/$data->id")', ), //图片 array( 'name'=>'image', 'type'=>'image', 'value'=>'LImages::getPath("book").$data->image',//图片相对路径 ), //下拉列表 array( 'name'=>'type', 'value'=>'Lookup::item("chapterType",$data->type)', 'filter'=>Lookup::items('chapterType'), ), //内容截取 array( 'name'=>'content', 'type'=>'html', 'value'=>'mb_substr(htmlspecialchars_decode($data->content),0,100,"utf-8")', ), //时间 array( 'name'=>'create_time', 'type'=>'datetime', ), // 根据相关信息读数据库 array( 'name'=>'user_id', 'value'=>'User::model()->findbyPk($data->user_id)->username', 'filter'=>false, ), array( 'class'=>'CButtonColumn', ), ),)); ?>