我在将下面的SQL转换为Zend Db查询时遇到了一些问题。使用Zend DB编写子查询
$select = ' SELECT s.id, i.id as instance_id, i.reference, i.name, i.sic_code, i.start_date
FROM sles s
JOIN sle_instances i
ON s.id = i.sle_id
WHERE i.id = ( SELECT MAX(id)
FROM sle_instances
WHERE sle_id = s.id
)
ORDER BY i.name ASC';
我已经得到了尽可能的代码 - 但Zend Db没有正确地产生查询。任何人都可以告诉我我缺少什么?
$select = $db->select() ->from('sles', array( 'id',
'instance_id' => 'sle_instances.id',
'reference' => 'sle_instances.reference',
'name' => 'sle_instances.name',
'sic_code' => 'sle_instances.sic_code',
'start_date' => 'sle_instances.start_date'
)
)
->join('sle_instances', 'sles.id = sle_instances.sle_id')
->where('sles.id = (SELECT MAX(id) FROM sle_instances WHERE sle_id = sles.id)')
->order('sle_instances.name ASC');
SQL确实有效。我正在使用Zend Db重写它,因为我希望使用Zend Paginator功能。
任何帮助是极大的赞赏。
PJ
什么是$ db? – 2016-01-28 13:34:37