cakephp2.X多表联合查询join及使用分页查询的方法


Posted in PHP onFebruary 23, 2017

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

格式化参数:

public function getconditions($data){
  $this->loadModel("Cm.LoginHistory");
  $conditions = array();
  foreach ($data as $key=>$val){
    if($key=='start_date'){
      $conditions['LoginHistory.logintime >=']=trim($val);
    }elseif ($key=='end_date'){
      $conditions['LoginHistory.logouttime <=']=trim($val);
    }elseif ($key=='selectvsoftid' and $val !=''){
      $conditions['LoginHistory.LOGINSUBSYSTEM LIKE']='%'.trim($val).'%';
    }elseif ($key=='username' and $val !=''){
      $conditions['LoginHistory.USERNAME LIKE']='%'.trim($val).'%';
    }elseif ($key=='vdevicename' and $val !=''){
      $conditions['LoginHistory.WINDOWNAME LIKE']='%'.trim($val).'%';
    }elseif ($key=='selectvsoftid' and $val !=''){
      $conditions['LoginHistory.PHDEVICENAME LIKE']='%'.trim($val).'%';
    }
  }
  return $conditions;
}

分页查询:

$fields = array('LoginHistory.windowname','LoginHistory.loginsubsystem','VirtualDevice.PHDEVICEID','LoginHistory.userid', 'VirtualDevice.SYSTYPEID','UserInfo.USERNAME','"SUM"(LoginHistory.LOGOUTTIME-LoginHistory.LOGINTIME) moument','UserInfo.USERNAME','DeviceInfo.DEVICENAME');
$group=array('LoginHistory.windowname', 'LoginHistory.loginsubsystem', 'LoginHistory.userid','UserInfo.USERNAME','DeviceInfo.DEVICENAME','VirtualDevice.SYSTYPEID','VirtualDevice.PHDEVICEID');
$this->paginate = array('conditions'=>$conditions,'fields'=>$fields,'group'=>$group,'limit'=>9,'joins' => array(
   array(
     'alias' => 'UserInfo',
     'table' => 'SMM_USERINFO',
     'type' => 'LEFT',
     'conditions' => ' LoginHistory.USERID=UserInfo.USERID ',
   ),
   array(
     'alias' => 'VirtualDevice',
     'table' => 'ET_NMVIRTUALDEVICEINFO',
     'type' => 'LEFT',
     'conditions' => ' LoginHistory.WINDOWNAME=VirtualDevice.DEVICENAME ',
   ),
   array(
     'alias' => 'DeviceInfo',
     'table' => 'ET_NMDEVICEINFO',
     'type' => 'LEFT',
     'conditions' => ' VirtualDevice.PHDEVICEID=DeviceInfo.DEVICEID ',
   ),
 ));
$LoginHistory = $this->paginate('LoginHistory');
$this->set('loginhistory',$LoginHistory);

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

PHP 相关文章推荐
eWebEditor v3.8 商业完整版 (PHP)
Dec 06 PHP
php下实现一个阿拉伯数字转中文数字的函数
Jul 10 PHP
php 模拟post_验证页面的返回状态(实例讲解)
Oct 28 PHP
使用PHP生成二维码的方法汇总
Jul 22 PHP
PHP实现简单的新闻发布系统实例
Jul 28 PHP
PHP模块化安装教程
Jun 01 PHP
PHP入门教程之图像处理技巧分析
Sep 11 PHP
PHP数据库操作二:memcache用法分析
Aug 16 PHP
Laravel中Facade的加载过程与原理详解
Sep 22 PHP
Thinkphp5行为使用方法汇总
Dec 21 PHP
PHP+ajax实现获取新闻数据简单示例
May 08 PHP
PHP PDOStatement::columnCount讲解
Jan 30 PHP
PHP获取中国时间(上海时区时间)及美国时间的方法
Feb 23 #PHP
php实现的XML操作(读取)封装类完整实例
Feb 23 #PHP
利用php生成验证码
Feb 23 #PHP
php实现base64图片上传方式实例代码
Feb 22 #PHP
php中实现字符串翻转的方法
Feb 22 #PHP
php生成图片缩略图功能示例
Feb 22 #PHP
php图形jpgraph操作实例分析
Feb 22 #PHP
You might like
一个简单的PHP&amp;MYSQL留言板源码
2020/07/19 PHP
用PHP写的基于Memcache的Queue实现代码
2011/11/27 PHP
PHP strstr 函数判断字符串是否否存在的实例代码
2013/09/28 PHP
php上传图片存入数据库示例分享
2014/03/11 PHP
php开启openssl的方法
2014/05/15 PHP
PHP编写RESTful接口的方法
2016/02/21 PHP
JavaScript 事件查询综合
2009/07/13 Javascript
javascript天然的迭代器
2010/10/29 Javascript
自己动手制作jquery插件之自动添加删除行的实现
2011/10/13 Javascript
js实现图片轮换效果代码
2013/04/16 Javascript
Event altKey,ctrlKey,shiftKey属性解析
2013/12/18 Javascript
javascript数据结构中栈的应用之符号平衡问题
2017/04/11 Javascript
AngularJS自定义指令实现面包屑功能完整实例
2017/05/17 Javascript
jQuery+css last-child实现选择最后一个子元素操作示例
2018/12/10 jQuery
详解Node.JS模块 process
2020/08/31 Javascript
[09:37]2018DOTA2国际邀请赛寻真——不懈追梦的Team Serenity
2018/08/13 DOTA
[02:10]DOTA2 TI10勇士令状玩法及不朽Ⅰ展示:焕新世界,如你所期
2020/05/29 DOTA
Python程序员开发中常犯的10个错误
2014/07/07 Python
使用httplib模块来制作Python下HTTP客户端的方法
2015/06/19 Python
python基础入门学习笔记(Python环境搭建)
2016/01/13 Python
Python基于matplotlib画箱体图检验异常值操作示例【附xls数据文件下载】
2019/01/07 Python
PyTorch 随机数生成占用 CPU 过高的解决方法
2020/01/13 Python
Python递归求出列表(包括列表中的子列表)的最大值实例
2020/02/27 Python
N.Peal官网:来自伦敦的高档羊绒品牌
2018/10/29 全球购物
洛杉矶时尚女装系列:J.ING US
2019/03/17 全球购物
中学教师实习自我鉴定
2013/09/28 职场文书
人力资源行政经理自我评价
2013/10/23 职场文书
眼镜促销方案
2014/03/15 职场文书
优秀学生干部个人事迹材料
2014/06/02 职场文书
原料仓仓管员岗位职责
2014/07/08 职场文书
党的群众路线教育实践活动总结
2014/10/30 职场文书
入党政审材料范文
2014/12/24 职场文书
勇敢的心观后感
2015/06/09 职场文书
商业计划书范文
2019/04/24 职场文书
SQLServer2019 数据库环境搭建与使用的实现
2021/04/08 SQL Server
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
2021/04/29 HTML / CSS