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

2025-05-27 0 97

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

格式化参数:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

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

}

分页查询

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24
$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程序设计有所帮助。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 cakephp2.X多表联合查询join及使用分页查询的方法 https://www.kuaiidc.com/73057.html

相关文章

发表评论
暂无评论