左边加入cakephp 1.3

时间:2013-01-31 05:16:19

标签: php oracle cakephp

如何在cakePHP 1.3上创建此查询

 SELECT "Redeem_log"."benefit_id", count("Redeem_log"."benefit_id") as JUMLAH FROM  "redeem_logs" "Redeem_log" 
LEFT JOIN "benefits" "Benefit" ON ("Redeem_log"."benefit_id" = "Benefit"."id") 
LEFT JOIN "merchants" "Merchant" ON ("Benefit"."merchant_id" = "Merchant"."id")  
LEFT JOIN "merchant_types" "Merchant_type" ON ("Merchant"."merchant_type_id" = "Merchant_type"."id") 
WHERE "Redeem_log"."benefit_id" IS NOT NULL AND ("Merchant_type"."merchant_type"='lokal' OR "Merchant_type"."merchant_type"='nasional') GROUP BY "Redeem_log"."benefit_id"  ORDER BY "JUMLAH" DESC  

我不想使用belongsTO,hasMany或ect
如果我使用

var $belongsTo = array(
    'Benefit' => array('className' => 'Benefit',     'foreignKey' => 'benefit_id'),
    'Merchant' => array('className' => 'Merchant', 'foreignKey' => 'merchant_id')
);

左连接就像:

SELECT "Redeem_log"."benefit_id", count("Redeem_log"."benefit_id") as JUMLAH 
FROM "redeem_logs" "Redeem_log" 
LEFT JOIN "benefits" "Benefit" ON ("Redeem_log"."benefit_id" = "Benefit"."id") 
LEFT JOIN "merchants" "Merchant" ON ("Redeem_log"."merchant_id" = "Merchant"."id") 
WHERE "Redeem_log"."benefit_id" IS NOT NULL  GROUP BY "Redeem_log"."benefit_id"  
ORDER BY "JUMLAH" DESC  

2 个答案:

答案 0 :(得分:0)

我会这样做,查询的参数看起来有点可怕,但当你仔细研究它时,它是有道理的:

$params = array(
    'recursive' => -1,
    'fields' => array('RedeemLog.benefit_id', 'COUNT(RedeemLog.benefit_id) as JUMLAH'),
    'conditions' => array(
        array('NOT' => array('RedeemLog.benefit_id' => null)),
        array('Merchanttype.merchant_type' => array('lokal', 'nasional')),
     ),
     'joins' => array(
         array(
             'table' => 'benefits',
             'alias' => 'Benefit',
             'type' => 'LEFT',
             'conditions' => array('RedeemLog.benefit_id = Benefit.id')
         ),
         array(
            'table' => 'merchants',
            'alias' => 'Merchant',
            'type' => 'LEFT',
            'conditions' => array('Benefit.merchant_id = Merchant.id')
         ),
         array(
            'table' => 'merchant_types',
            'alias' => 'Merchanttype',
            'type' => 'LEFT',
            'conditions' => array('Merchant.merchant_type_id = Merchanttype.id')
         ),
     ),
     'order' => 'JUMLAH DESC',
     'group' => 'RedeemLog.benefit_id',
 );
最后,蛋糕找到了

 $result = $this->RedeemLog->find('all', $params);

希望它适合你。

答案 1 :(得分:0)

在MOdel :: find();

的params参数中添加连接字段 像这样

$params = array(
    'joins'=>array(
         array(
             'table'=>'users',
             'alias'=>'User',
             'type'=>'LEFT/RIGHT/INNER',
             'conditions'=>array("$this->Alias.foreignKey=User.pk")
         )
     )
);