YII框架讲解
Yii::app() 是CwebApplication类实例化的对象
CwebApplication(framework/web/CwebApplication.php)
因此Yii::app()可以调用CwebApplication 或父类 CApplication
我们可以通过Yii::app() 调用系统的组件
User session request log db等等
在系统的任何角落都可以直接访问以上组件
Yii ::app()->user (实例化对象'CWebUser' => '/web/auth/CWebUser.php',)
控制器—-》父类控制器—-》compoments—main.php—-index.php
main.php中import可引入组件,model,module等
render 和renderpartial之间最大的区别就是:一个是渲染模板,一个不渲染模板。
其中render 输出父模板的内容,将渲染的内容,嵌入父模板即layout文件夹中文件。
renderPartial 则不输出父模板的内容。只对本次渲染的局部内容
gii模块如何来访问:先判断是否是模块名是的话直接找,不是的话去找控制器
通过路由形式访问该模块
http://web.0507shop.com/index.php?r=模块名字
http://url/index.php?r=gii
框架里model就是一个类,属性就是数据表的字段
yii模块中module可以调用 前台model,所以在前台写即可
yii AR模型
goodsmodel=Goods::model();//只挑出一条记录
goods_info =
goodsmodel−>find();//获得全部商品信息,是一个大的数组,里面有具体对象元素,遍历出来结果是每条记录对象
goods_info = $goods_model->findAll();
SELECT * from one_table where username = ‘admin’ and password = ‘123456’;
对应的AR model查询如下
Admin::model()->findAllByAttributes(array(‘username’=>’admin’, ‘password’=>’123456’));
通过具体sql语句获得信息】
AR:findAllBysql();
操作数据库增删改通过模型创建对象来操作,
对象调用 相关方法实现操作即原生的new对象来
我们使用模型model步骤:
1.创建模型对象
①模型名字::model()
②new 模型模型()
2.利用对象调用模型里边的一些方法,实现对数据的操作
表单展现:model
attributeLabels() 模型属性与汉字标签名字对应
new Goods() 和 Goods::model()
都可以进行查询
前者主要是在添加的时候使用,后者是在查询或修改的时候使用。
切记
function actionUpdat(
id,
name,tp){
//除了添加数据都使用Goods::model()实例化对象goods_model = Goods::model();
//
goodsmodel−>updateByPk(
id,array(‘goods_name’=>’龙龙龙龙’),
condition,
params);
goodsinfo=
goods_model->findByPk($id);
//修改的时候,
//创建数据模型model对象
//new Good():调用save()方法执行insert语句
//Goods::model() 调用save()方法时执行update语句
if(isset($_POST['submit'])){
foreach($_POST['Goods'] as $k=> $v){
$goods_info->$k = $v;
}
$goods_info->save();
}
$this ->renderPartial('update',array('goods_model'=>$goods_info));
}
【数据查询延伸】
AR(CActiveRecord)活跃记录
find() 查询一个信息
findByPk 根据主键查询信息
findBySql根据sql语句查询信息
findAll()查询全部信息
findAllByPk 根据主键查询全部信息
findAllBySql根据sql语句查询全部信息
findBySql 和 findAllBySql
根据sql语句查询信息,前者会查询一条记录信息,后者会查询条记录信息
前者给返回一个数据模型对象,后者以数组形式给我们返回多个数据模型对象
select * from goods limit 10
findByPk 和 findAllByPk
都是根据主键进行信息的查询
前者每次只可以传递一个主键信息,后者可以传递一个也传递多个
后者传递参数,如果是多个主键信息,需要以数组形式给我们传递。
select condition order limit offset 都是从哪来的。
AR需要最终转变为具体的sql语句,通过一个中间类(criteria标准)协助转为的具体sql语句,上边的关键字就是这个中间类criteria的一些属性。
usermodel−>attributes=
_POST[‘User’];
attributes这个属性在使用的时候会收集表单信息并赋予模型属性里边
该属性是和rules()方法一并使用,只有在rules()里边设置了验证规则的属性才可以被attributes接收
如果有的属性没有具体验证规则,则给一个safe规则。
【用户退出系统同时删除session和cookie】
Yii ::app()->user->logout() ;
【如何获得当前控制器和方法】
//当前控制器user
echo
this−>id;//当前方法loginecho
this->action->id
Duration、varyByParam、dependency这个几个属性在哪?
System.web.widgets.CoutputCache.php
我们是否可以在布局进行页面缓存
答:理论上不可以,视图先加载,布局后加载
视图:0.05135800 1369315232 时间小,先加载
布局:0.05197600 1369315232 时间打,后加载