douhui3330 2015-08-27 09:02
浏览 64
已采纳

CakePHP加入内部

I need to do the following query using the CakePHP find method:

SELECT * FROM `ads`
INNER JOIN fields_values ON fields_values.ref_id = ad.id 
WHERE ad.active = 1

I tried this function, but she doesn't work :

$ads = $this->Ad->find('all', array(
            'joins' => array(
                array(
                    'table' => 'fields_values',
                    'alias' => 'fv',
                    'type' => 'INNER',
                    'conditions' => array(
                        "Ad.id = fv.ref_id "
                    )
                )
            ),
            'conditions' => array(
                'Ad.active' => 1
            ),
        ));
  • 写回答

1条回答 默认 最新

  • dtp19819 2015-08-27 09:05
    关注

    your query is wrong it should be

    SELECT * FROM `ads`
    INNER JOIN fields_values as fv ON fv.ref_id = ads.id 
    WHERE ads.active = 1
    

    Now you can build it up with cake query. Which left join also does it.

    $ads = $this->Ad->find('all', array(
                'conditions' => array(
                    'Ad.active' => 1
                ),
                'joins' => array(
                    array(
                        'table' => 'fields_values',
                        'alias' => 'fv',
                        'type' => 'LEFT',
                        'conditions' => array(
                            "fv.ref_id = Ad.id",
                            // or you can add the top condition here
                            //'Ad.active' => 1
                        )
                    )
                ),
            ));
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥60 求一个简单的网页(标签-安全|关键词-上传)
  • ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法
  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP