我有一个问题,我正在尝试计算每个给定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行,则查询返回正常(尽管结果错误)。知道如何让子查询识别父表的列在我的条件下使用吗?感谢。
答案 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`
如果有效,请告诉我,这是我们正在研究的一个有趣问题。