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

jerry Yii 2015年11月24日 收藏

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

  • CActiveDataProvider  基于Active Record的数据源
  • CArraryDataProvider 基于数组的数据源
  • CSqlDataProvider      基于SQL查询的数据源

201212128001

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

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

如:

  1. $dataProvider=new CActiveDataProvider('Post', array(
  2. 'criteria'=>array(
  3. 'condition'=>'status=1',
  4. 'order'=>'create_time DESC',
  5. 'with'=>array('author'),
  6. ),
  7. 'pagination'=>array(
  8. 'pageSize'=>20,
  9. ),
  10. ));
  11. // $dataProvider->getData() will return a list of Post objects

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

  1. $rawData=Yii::app()->db->createCommand('SELECT * FROM tbl_user')->queryAll();
  2. // or using: $rawData=User::model()->findAll();
  3. $dataProvider=new CArrayDataProvider($rawData, array(
  4. 'id'=>'user',
  5. 'sort'=>array(
  6. 'attributes'=>array(
  7. 'id', 'username', 'email',
  8. ),
  9. ),
  10. 'pagination'=>array(
  11. 'pageSize'=>10,
  12. ),
  13. ));
  14. // $dataProvider->getData() will return a list of arrays.

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

  1. $count=Yii::app()->db->createCommand('SELECT COUNT(*) FROM tbl_user')->queryScalar();
  2. $sql='SELECT * FROM tbl_user';
  3. $dataProvider=new CSqlDataProvider($sql, array(
  4. 'totalItemCount'=>$count,
  5. 'sort'=>array(
  6. 'attributes'=>array(
  7. 'id', 'username', 'email',
  8. ),
  9. ),
  10. 'pagination'=>array(
  11. 'pageSize'=>10,
  12. ),
  13. ));
  14. // $dataProvider->getData() will return a list of arrays.

关于DataProvider详细文档可以参见