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

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

格式化参数:

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; }

分页查询:

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’,’conditions’ => ‘ LoginHistory.WINDOWNAME=VirtualDevice.DEVICENAME ‘,array( ‘alias’ => ‘DeviceInfo’,’table’ => ‘ET_NMDEVICEINFO’,’conditions’ => ‘ VirtualDevice.PHDEVICEID=DeviceInfo.DEVICEID ‘,)); $LoginHistory = $this->paginate(‘LoginHistory’); $this->set(‘loginhistory’,$LoginHistory);

更多关于php框架相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》及《》

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

dawei

【声明】:丽水站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

相关文章