点击这里给我发消息 点击这里给我发消息

PHP开发框架Yii Framework教程(28) Data Provider简介

添加时间:2013-12-6
    相关阅读: 开发 数据库 SQL PHP 框架
 

这开始介绍Zii组件之前,先简要介绍一下Yii支持的数据源接口 IDataProvider,IDataProvider主要功能是为UI组件如 GridView,ListView等提供数据源,同时也支持数据的分页和排序。下图为Yii内置的三种数据源:

CActiveDataProvider  基于Active Record的数据源

CArraryDataProvider 基于数组的数据源

CSqlDataProvider      基于SQL查询的数据源

三种Data Provider的使用大同小异:

CActiveDataProvider 基于ActiveRecord, 它通过AR的 CActiveRecord::findAll方法读取数据库记录,并通过 criteria属性设置查询条件。

如:

$dataProvider=new

CActiveDataProvider('Post', array(    
    'criteria'=>array(    
        'condition'=>'status=1',    
        'order'=>'create_time DESC',    
        'with'=>array('author'),    
    ),    
    'pagination'=>array(    
        'pageSize'=>20,    
    ),    
));    
// $dataProvider->getData() will return a list of Post objectsCArrayDataProvider

基于数组,其中属性 rawData设置原始数据,一般为数组或者DAO查询结果,如:

$rawData=Yii::app()->db->createCommand

('SELECT * FROM tbl_user')->queryAll();    
// or using: $rawData=User::model()->findAll();    
$dataProvider=new CArrayDataProvider($rawData, array(    
    'id'=>'user',    
    'sort'=>array(    
        'attributes'=>array(    
             'id', 'username', 'email',    
        ),    
    ),    
    'pagination'=>array(    
        'pageSize'=>10,    
    ),    
));    
// $dataProvider->getData() will return a list of arrays.CSqlDataProvider

基于SQL查询,通过设置 sql 语句来配置,比如:

$count=Yii::app()->db->createCommand('SELECT COUNT(*) FROM tbl_user')-

>queryScalar();    
$sql='SELECT * FROM tbl_user';    
$dataProvider=new CSqlDataProvider($sql, array(    
    'totalItemCount'=>$count,    
    'sort'=>array(    
        'attributes'=>array(    
             'id', 'username', 'email',    
        ),    
    ),    
    'pagination'=>array(    
        'pageSize'=>10,    
    ),    
));    
// $dataProvider->getData() will return a list of arrays.

关于DataProvider详细文档可以参见Yii文档:

http://www.yiiframework.com/doc/api/1.1/CDataProvider

咨询热线:020-85648757 85648755 85648616 0755-27912581 客服:020-85648756 0755-27912581 业务传真:020-32579052
广州市网景网络科技有限公司 Copyright◎2003-2008 Veelink.com. All Rights Reserved.
广州商务地址:广东省广州市黄埔大道中203号(海景园区)海景花园C栋501室
= 深圳商务地址:深圳市宝源路华丰宝源大厦606
研发中心:广东广州市天河软件园海景园区 粤ICP备05103322号 工商注册