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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值