如何使用find方法在cakePHP中创建子查询?例如:
SELECT *, (SELECT COUNT(*) FROM table2 WHERE table2.field1 = table1.id) AS count
FROM table1
WHERE table1.field1 = 'value'
!!! table2.field1=表1.id!!!
最佳答案
你可以用两种方法之一:
一。使用$this->模型->查询(…)
这允许您使用上面发布的查询直接执行SQL,但要注意,如果数据库模式发生更改,它会使应用程序变得非常脆弱。可能是最快的
例子
$this->Model1->query("SELECT * FROM model;");
2。分开通话
这可能没有选项1那么快,但它确实使您能够将查询分解为多个步骤。您也不太可能得到SQL注入,这是选项1的潜在风险。
例子
$model1s = $this->Model1->find
(
'all',
array
(
'conditions' => array('Model1.field1' => 'value')
)
);
foreach($model1s as $model1)
{
$model1['model2_count'] = $this->Model2->find
(
'count',
array
(
'conditions' => array
(
'Model2.field1' => $model1['id']
)
)
);
}