模型:对连接语句应用条件

时间:2018-09-04 11:43:04

标签: php lithium

我想在模型的联接上添加一些条件。

这是我尝试过的,结果没有任何改变:

    Members::find('all', [
        'fields' => ['name', 'Count(Orders.id)'],
        'with' => 'Orders',
        // 'joins' => [
        //  'Orders' => 'Orders.status = delivered'
        // ]
    ]);

这是我的工作示例查询:

SELECT name, COUNT(orders.id) FROM members
LEFT JOIN orders ON orders.member_id = members.id AND orders.status = 'delivered'
GROUP BY member_id

编辑:

我也尝试过基于this answer

的这种方法
$joins = array();
$joins[] = new \lithium\data\model\Query(array(
     'source' => 'orders',
     'type' => 'LEFT',
     'constraint' => array('Orders.status' => 'delivered'),
));


Members::find('all', [
    'fields' => ['name', 'Count(Orders.id)'],
    'with' => 'Orders',
    'joins' => $joins
]);

但是创建的查询不包含定义的联接参数('Orders.status'=>'已交付')

1 个答案:

答案 0 :(得分:1)

您尝试做的事情在概念上是错误的。请尝试将status = 'delivered'放在查询的where子句中。有关更多信息,请阅读以下内容:

尽管您正在编写的查询在读取时很有意义,并且(可能)产生相同的结果,但是您正在混合join clausewhere clause

  • Join clause应该包含将两个记录“连接”在一起所需的条件(即,相同的名称,相同的名字和姓氏,相同的品牌和型号等)

  • Where clause应该包含仅返回满足条件的记录所必需的条件。这些记录可以来自单个表(通常),也可以来自多个表(如果有联接)。