如何获取嵌套子查询以识别父查询列

时间:2011-08-17 04:50:28

标签: mysql subquery aggregate-functions nested-query

我有一个问题,我正在尝试计算每个给定ID的值之和。我决定使用子查询来执行此操作(通常我会使用连接,但我也为每个子查询保留一个计数器以用于剪切目的 - see this question以获取更多信息)。为了这个问题,假设我有以下 MySQL 查询:

/* 1.  */  SELECT 
/* 2.  */      t1.experiement_id,
/* 3.  */      (SELECT  sum(x.size) 
/* 4.  */       FROM    (SELECT size, ( @rownum := @rownum + 1 ) AS `rownum`
/* 5.  */                FROM   data AS t0 
/* 6.  */                JOIN ( select @rownum := 0 ) 
/* 7.  */                WHERE  t0.experiment_id = t1.experiment_id
/* 8.  */                ORDER BY size) AS x
/* 9.  */                WHERE x.rownum <= t2.clip_index ) AS `sum`
/* 10. */  
/* 11. */  FROM data      AS t1
/* 12. */  JOIN data_clip AS t2 USING (experiment_id)
/* 13. */  
/* 14. */  GROUP BY t1.experiment_id

问题发生在行7上,我正在尝试隔离与experiement_id匹配的子查询中的行 - 我收到的错误t1.experiement_id是未知栏目。这只发生在嵌套深度超过1级的查询中。就像检查一样,我注意到t2.clip_index处理正常。如果我注释掉第7行,则查询返回正常(尽管结果错误)。知道如何让子查询识别父表的列在我的条件下使用吗?感谢。

1 个答案:

答案 0 :(得分:1)

您是否曾尝试过类似行来计算行而不是用户定义的变量?

(SELECT sum(size) FROM  data AS t0                  
WHERE  t0.experiment_id = t1.experiment_id
ORDER BY size HAVING COUNT(*)<=t2.clip_index
) AS `sum` 

如果有效,请告诉我,这是我们正在研究的一个有趣问题。