cakephp2.X多表聯(lián)合查詢join及使用分頁查詢的方法
本文實(shí)例講述了cakephp2.X多表聯(lián)合查詢join及使用分頁查詢的方法。分享給大家供大家參考,具體如下:
格式化參數(shù):
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);
更多關(guān)于php框架相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php優(yōu)秀開發(fā)框架總結(jié)》、《codeigniter入門教程》、《ThinkPHP入門教程》、《Zend FrameWork框架入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
thinkPHP使用post方式查詢時(shí)分頁失效的解決方法
這篇文章主要介紹了thinkPHP使用post方式查詢時(shí)分頁失效的解決方法,通過使用JavaScript動態(tài)修改頁面元素結(jié)合thinkPHP查詢語句解決分頁失效的問題,需要的朋友可以參考下2015-12-12
phpmyadmin 常用選項(xiàng)設(shè)置詳解版
phpmyadmin常用選項(xiàng)設(shè)置,以phpmyadmin2.5.4為例2010-03-03
php+jquery+html實(shí)現(xiàn)點(diǎn)擊不刷新加載更多的實(shí)例代碼
下面小編就為大家?guī)硪黄猵hp+jquery+html實(shí)現(xiàn)點(diǎn)擊不刷新加載更多的實(shí)例代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08
使用swoole擴(kuò)展php websocket示例
WebSocket規(guī)范的目標(biāo)是在瀏覽器中實(shí)現(xiàn)和服務(wù)器端雙向通信。雙向通信可以拓展瀏覽器上的應(yīng)用類型,如果你想要用PHP來寫websocket應(yīng)用,那swoole_framework一定是最好的選擇,需要的朋友可以參考下2014-02-02
PHP后臺備份MySQL數(shù)據(jù)庫的源碼實(shí)例
今天小編就為大家分享一篇關(guān)于PHP后臺備份MySQL數(shù)據(jù)庫的源碼實(shí)例,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03
laravel Validator ajax返回錯(cuò)誤信息的方法
今天小編就為大家分享一篇laravel Validator ajax返回錯(cuò)誤信息的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
PHP+ajaxfileupload+jcrop插件完美實(shí)現(xiàn)頭像上傳剪裁
在做項(xiàng)目的時(shí)候,經(jīng)常需要一些會員系統(tǒng)相關(guān)的內(nèi)容,比如頭像的上傳與裁剪等等,下面將這塊內(nèi)容分享給大家2014-06-06

