zoukankan      html  css  js  c++  java
  • YII框架分析笔记8:CDataProvider

    CDataProvider,顾名思义,数据提供者,它提供了三个抽象方法(fetchData,、fetchKeys 和 calculateTotalItemCount),分别为调用不同数据结构的数据提供了获取数据、获取键值、获取数量的,接口,在YII框架 中,CActiveDataProvider、CArrayDataProvider、CSqlDataProvider是它的子类,除了提供数据之外, 他还提供分页和排序功能。下面以获取数据fetchData()为例

    CActiveDataProvider通过CActiveRecord的子类和CDbCriteria对象

    1. /** 
    2.     * Fetches the data from the persistent data storage. 
    3.     * @return array list of data items 
    4.     */  
    5. protected function fetchData()  
    6. {  
    7.     $criteria=clone $this->getCriteria();  
    8.   
    9.     if(($pagination=$this->getPagination())!==false)  
    10.     {  
    11.         $pagination->setItemCount($this->getTotalItemCount());  
    12.         $pagination->applyLimit($criteria);  
    13.     }  
    14.   
    15.     $baseCriteria=$this->model->getDbCriteria(false);  
    16.   
    17.     if(($sort=$this->getSort())!==false)  
    18.     {  
    19.         // set model criteria so that CSort can use its table alias setting  
    20.         if($baseCriteria!==null)  
    21.         {  
    22.             $c=clone $baseCriteria;  
    23.             $c->mergeWith($criteria);  
    24.             $this->model->setDbCriteria($c);  
    25.         }  
    26.         else  
    27.             $this->model->setDbCriteria($criteria);  
    28.         $sort->applyOrder($criteria);  
    29.     }  
    30.   
    31.     $this->model->setDbCriteria($baseCriteria!==null ? clone $baseCriteria : null);  
    32.     $data=$this->model->findAll($criteria);  
    33.   
    34.     $this->model->setDbCriteria($baseCriteria);  // restore original criteria  
    35.     return $data;  
    36. }  

    CArrayDataProvider通过传人的原生数据来获取数据

    1. /** 
    2.     * Fetches the data from the persistent data storage. 
    3.     * @return array list of data items 
    4.     */  
    5. protected function fetchData()  
    6. {  
    7.     if(($sort=$this->getSort())!==false && ($order=$sort->getOrderBy())!='')  
    8.         $this->sortData($this->getSortDirections($order));  
    9.   
    10.     if(($pagination=$this->getPagination())!==false)  
    11.     {  
    12.         $pagination->setItemCount($this->getTotalItemCount());  
    13.         return array_slice($this->rawData, $pagination->getOffset(), $pagination->getLimit());  
    14.     }  
    15.     else  
    16.         return $this->rawData;  
    17. }  

    CSqlDataProvider通过传人的sql,经过db执行获取数据

      1. /** 
      2.     * Fetches the data from the persistent data storage. 
      3.     * @return array list of data items 
      4.     */  
      5. protected function fetchData()  
      6. {  
      7.     $sql=$this->sql;  
      8.     $db=$this->db===null ? Yii::app()->db : $this->db;  
      9.     $db->active=true;  
      10.   
      11.     if(($sort=$this->getSort())!==false)  
      12.     {  
      13.         $order=$sort->getOrderBy();  
      14.         if(!empty($order))  
      15.         {  
      16.             if(preg_match('/s+orders+bys+[ws,]+$/i',$sql))  
      17.                 $sql.=', '.$order;  
      18.             else  
      19.                 $sql.=' ORDER BY '.$order;  
      20.         }  
      21.     }  
      22.   
      23.     if(($pagination=$this->getPagination())!==false)  
      24.     {  
      25.         $pagination->setItemCount($this->getTotalItemCount());  
      26.         $limit=$pagination->getLimit();  
      27.         $offset=$pagination->getOffset();  
      28.         $sql=$db->getCommandBuilder()->applyLimit($sql,$limit,$offset);  
      29.     }  
      30.   
      31.     $command=$db->createCommand($sql);  
      32.     foreach($this->params as $name=>$value)  
      33.         $command->bindValue($name,$value);  
      34.   
      35.     return $command->queryAll();  
  • 相关阅读:
    【转】进程间通信方式总结(windows 和linux)
    Python-Analysis-Malware
    现场取证之流量分析总结
    木马通信与防护墙穿透
    【PE结构】恶意代码数字签名验证
    32位与64位架构上的区别
    【API】网络编程模型、多线程
    【API】遍历进程的几种方式
    【病毒取样】取证分析之逆向服务器提权开启3389远程连接工具
    【CTF WEB】XSS-https://alf.nu/alert1
  • 原文地址:https://www.cnblogs.com/sunscheung/p/4827127.html
Copyright © 2011-2022 走看看