首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >选择子查询的结果

选择子查询的结果
EN

Stack Overflow用户
提问于 2014-01-15 23:40:24
回答 2查看 106关注 0票数 0

我正在尝试选择FROM子查询的结果q1.res

代码语言:javascript
复制
    (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.idid列)

代码语言:javascript
复制
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

问题出在哪里?

EN

回答 2

Stack Overflow用户

发布于 2014-01-15 23:47:30

尝试从子查询的'res‘中删除’‘。

代码语言:javascript
复制
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
票数 0
EN

Stack Overflow用户

发布于 2014-01-16 00:02:49

您需要提到DB对象'g‘所指的是什么。这意味着,您需要将其指定为'FROM‘部分中的一个表(或视图),要么作为一个纯交叉引用,要么--如果您愿意的话--然后使用某种联接。

e.g

代码语言:javascript
复制
SELECT SUM(gwr.res1)/(COUNT(*)*1000) as 'res' 
FROM process.gwr, process.g 
WHERE started = 1 
    AND gwr.user2 = g.id 
    AND gwr.loss = g.id 

请注意“FROM”部分中的“process.g”。

希望这能帮上忙。

K

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21141749

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档