首頁 >後端開發 >php教程 >PHP開發框架Yii Framework教學(28) Data Provider簡介

PHP開發框架Yii Framework教學(28) Data Provider簡介

黄舟
黄舟原創
2017-01-22 09:34:591346瀏覽

這開始介紹Zii元件之前,先簡單介紹Yii支援的資料來源介面 IDataProvider,IDataProvider主要功能是為UI元件如 GridView,ListView等提供資料來源,同時也支援資料的分頁與排序。下圖為Yii內建的三種資料來源:

CActiveDataProvider 基於Active Record的資料來源

CArraryDataProvider 基於陣列的資料來源

CSqlDataProvider 基於SQL查詢的資料來源

CSqlDataProvider 基於SQL查詢的資料來源

PHP開發框架Yii Framework教學(28) 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.

以上就是PHP開發框架Yii Framework教程(28) Data Provider簡介的內容,更多相關內容請關注PHP中文網(www.php.cn)!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn