Zend 2子查询列

时间:2015-04-16 20:46:25

标签: mysql sql zend-framework2 subquery expression

我想在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而不是限制,现在它可以正常工作。稍后会尝试调试为什么会发生这种情况..谢谢!

1 个答案:

答案 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);