【发布时间】:2014-02-04 04:15:28
【问题描述】:
我正在尝试选择 q1.res,这将是 FROM 子查询的结果:
(SELECT SUM(gwr.res1)/(COUNT(*)*1000) as 'res'
FROM process.gwr
WHERE started = 1 AND gwr.user2 = g.id AND gwr.loss = g.id) AS q1
问题是我试图在子查询中选择g.id,但由于某种原因它无法访问它并返回错误消息:
[Err] 1054 - Unknown column 'g.id' in 'where clause'
这没有意义,因为 g.id(grand.id 有 id 列)
SELECT
g.name, g.point, g.mx, q1.res
FROM
(SELECT SUM(gwr.res1)/(COUNT(*)*1000) as 'res'
FROM process.gwr
WHERE (started = 1) AND (gwr.user2 = g.id) AND (gwr.loss = g.id)) AS q1, grand g
LEFT JOIN process.users p ON (p.id = g.owner)
WHERE
p.name != ""
ORDER BY
g.point DESC,
g.mx DESC
LIMIT 5
问题出在哪里?
【问题讨论】:
-
是子查询执行正常还是你得到同样的错误?
-
@Milen Pavlov 它不会执行,因为我正在尝试使用主查询的 g.id。