查看: 1582|回复: 0

[PHP学习] cakephp2.X多表联合查询join及使用分页查询的方法

发表于 2017-12-13 08:00:02

本文实例讲述了cakephp2.X多表联合查询join及使用分页查询的方法。分享给大家供大家参考,具体如下:

格式化参数:

  1. public function getconditions($data){
  2. $this->loadModel("Cm.LoginHistory");
  3. $conditions = array();
  4. foreach ($data as $key=>$val){
  5. if($key=='start_date'){
  6. $conditions['LoginHistory.logintime >=']=trim($val);
  7. }elseif ($key=='end_date'){
  8. $conditions['LoginHistory.logouttime <=']=trim($val);
  9. }elseif ($key=='selectvsoftid' and $val !=''){
  10. $conditions['LoginHistory.LOGINSUBSYSTEM LIKE']='%'.trim($val).'%';
  11. }elseif ($key=='username' and $val !=''){
  12. $conditions['LoginHistory.USERNAME LIKE']='%'.trim($val).'%';
  13. }elseif ($key=='vdevicename' and $val !=''){
  14. $conditions['LoginHistory.WINDOWNAME LIKE']='%'.trim($val).'%';
  15. }elseif ($key=='selectvsoftid' and $val !=''){
  16. $conditions['LoginHistory.PHDEVICENAME LIKE']='%'.trim($val).'%';
  17. }
  18. }
  19. return $conditions;
  20. }
复制代码

分页查询:

  1. $fields = array('LoginHistory.windowname','LoginHistory.loginsubsystem','VirtualDevice.PHDEVICEID','LoginHistory.userid', 'VirtualDevice.SYSTYPEID','UserInfo.USERNAME','"SUM"(LoginHistory.LOGOUTTIME-LoginHistory.LOGINTIME) moument','UserInfo.USERNAME','DeviceInfo.DEVICENAME');
  2. $group=array('LoginHistory.windowname', 'LoginHistory.loginsubsystem', 'LoginHistory.userid','UserInfo.USERNAME','DeviceInfo.DEVICENAME','VirtualDevice.SYSTYPEID','VirtualDevice.PHDEVICEID');
  3. $this->paginate = array('conditions'=>$conditions,'fields'=>$fields,'group'=>$group,'limit'=>9,'joins' => array(
  4. array(
  5. 'alias' => 'UserInfo',
  6. 'table' => 'SMM_USERINFO',
  7. 'type' => 'LEFT',
  8. 'conditions' => ' LoginHistory.USERID=UserInfo.USERID ',
  9. ),
  10. array(
  11. 'alias' => 'VirtualDevice',
  12. 'table' => 'ET_NMVIRTUALDEVICEINFO',
  13. 'type' => 'LEFT',
  14. 'conditions' => ' LoginHistory.WINDOWNAME=VirtualDevice.DEVICENAME ',
  15. ),
  16. array(
  17. 'alias' => 'DeviceInfo',
  18. 'table' => 'ET_NMDEVICEINFO',
  19. 'type' => 'LEFT',
  20. 'conditions' => ' VirtualDevice.PHDEVICEID=DeviceInfo.DEVICEID ',
  21. ),
  22. ));
  23. $LoginHistory = $this->paginate('LoginHistory');
  24. $this->set('loginhistory',$LoginHistory);
复制代码

更多关于php框架相关内容感兴趣的读者可查看本站专题:《php优秀开发框架总结》、《codeigniter入门教程》、《ThinkPHP入门教程》、《Zend FrameWork框架入门教程》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家PHP程序设计有所帮助。



回复

使用道具 举报