我想在模型的联接上添加一些条件。
这是我尝试过的,结果没有任何改变:
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'=>'已交付')
答案 0 :(得分:1)
您尝试做的事情在概念上是错误的。请尝试将status = 'delivered'
放在查询的where子句中。有关更多信息,请阅读以下内容:
尽管您正在编写的查询在读取时很有意义,并且(可能)产生相同的结果,但是您正在混合join clause
和where clause
。
Join clause
应该包含将两个记录“连接”在一起所需的条件(即,相同的名称,相同的名字和姓氏,相同的品牌和型号等)
Where clause
应该包含仅返回满足条件的记录所必需的条件。这些记录可以来自单个表(通常),也可以来自多个表(如果有联接)。