您好,欢迎访问一九零五行业门户网

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

这篇文章主要介绍了cakephp2.x多表联合查询join及使用分页查询的方法,结合实例形式简单分析了cakephp查询及分页操作相关技巧,需要的朋友可以参考下
本文实例讲述了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全功能无变形图片裁剪的操作类与用法的介绍
thinkphp写数组插入与获取最新插入数据id的方法
以上就是cakephp2.x多表联合查询join及使用分页查询的方法介绍的详细内容。
其它类似信息

推荐信息