如何使用cakephp检索最后一组数据

时间:2015-06-24 08:01:00

标签: mysql cakephp

我的两张桌子图片如下:

enter image description here

我在TblB.php模型

中有关系
public $belongsTo = array('TblA');

我使用MySQL数据库;

$results = $this->TblB->find('all', array('group' => array('TblB.tbl_a_id')));

实际上,我需要表(tbl_b)中的最后一组数据。
如何使用CakePHP解决查询。

1 个答案:

答案 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的更多信息,请参阅文档。