yii 知识点

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 时间打,后加载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值