我想在Zend Framework 2中创建一个SQL(MySQL)查询,如:
SELECT a.id,
a.name,
a.age,
(SELECT MAX(score)
FROM scores AS s
WHERE s.user_id = a.id) AS max_score,
(SELECT SUM(time)
FROM games_played_time AS gpt
WHERE gpt.user_id = a.id) AS time_played
FROM users AS a
ORDER BY last_visited DESC
LIMIT 0, 100
请注意,这是现有查询的一个人为举例。
我尝试创建子查询,然后在我使用时创建主选择查询:
$select->columns(
array(
'id',
'name',
'age',
'max_score' => new Expression('?', array($sub1),
'time_played' => new Expression('?', array($sub2)
)
我也尝试过使用:
$subquery = new \Zend\Db\Sql\Expression("({$sub->getSqlString()})")
甚至像这里建议的lambda函数:http://circlical.com/blog/2014/1/27/zend-framework-2-subqueries-subselect-and-table-gateway
仍然没有运气,因为我一直都会遇到错误:
没有为预备陈述中的参数提供数据
当我成功地使查询工作时,它最终会包含子查询的文本。它开始看起来不可能在columns方法中创建多个表达式。有什么想法吗?
解决: 我以@Tim Klever提出的查询重写了查询。 Everythin工作除了一个查询。事实证明,在子查询和主查询中使用limit时存在某种问题。在我的情况下,其中一个子查询返回多行,所以我使用limit(1)来强制返回单个值。但是使用它会产生错误:
没有为预备陈述中的参数提供数据
我将查询更改为使用MAX而不是限制,现在它可以正常工作。稍后会尝试调试为什么会发生这种情况..谢谢!
答案 0 :(得分:3)
以下内容有助于我制作您列出的查询
$maxScoreSelect = new Select();
$maxScoreSelect->from(array('s' => 'scores'));
$maxScoreSelect->columns(array(new Expression('MAX(score)')));
$maxScoreSelect->where->addPredicates('s.user_id = a.id');
$sumTimeSelect = new Select();
$sumTimeSelect->from(array('gpt' => 'games_played_time'));
$sumTimeSelect->columns(array(new Expression('SUM(time)')));
$sumTimeSelect->where->addPredicates('gpt.user_id = a.id');
$select = new Select();
$select->from(array('a' => 'users'));
$select->columns(array(
'id',
'name',
'age',
'max_score' => new Expression('?', array($maxScoreSelect)),
'time_played' => new Expression('?', array($sumTimeSelect))
));
$select->order('last_visited DESC');
$select->limit(100);
$select->offset(0);