我的两张桌子图片如下:
我在TblB.php模型
中有关系public $belongsTo = array('TblA');
我使用MySQL数据库;
$results = $this->TblB->find('all', array('group' => array('TblB.tbl_a_id')));
实际上,我需要表(tbl_b)中的最后一组数据。
如何使用CakePHP解决查询。
答案 0 :(得分:0)
您希望运行以下SQL查询来获取所需的数据: -
SELECT TblB.* FROM tbl_b AS TblB WHERE TblB.id = (
SELECT TblB2.id FROM tbl_b AS TblB2
WHERE TblB2.tbl_a_id = TblB.tbl_a_id
ORDER BY TblB2.id DESC
LIMIT 1
)
ORDER BY TblB.id ASC
请参阅sqlfiddle了解此情况。
要在CakePHP中执行此操作,您需要使用Cake的buildStatement
构建子查询: -
$db = $this->TblB->getDataSource();
$subQuery = $db->buildStatement(
array(
'fields' => array('"TblB2"."id"'),
'table' => $db->fullTableName($this->TblB),
'alias' => 'TblB2',
'limit' => 1,
'offset' => null,
'joins' => array(),
'conditions' => array('"TblB"."tbl_a_id" = "TblB2"."tbl_a_id"'),
'order' => '"TblB2"."id" DESC',
'group' => null
)
);
$subQueryExpression = $db->expression($subQuery);
$conditions[] = $subQueryExpression;
$data = $this->TblB->find('all', compact('conditions'));
有关retrieving data using a sub-query的更多信息,请参阅文档。