通过别名分组嵌套查询

发布于 2025-01-29 01:58:39 字数 372 浏览 3 评论 0原文

我正在尝试按语句使用一个小组,以计算每个进度等级:

SELECT
with_avg.*, 
CASE
when T_Points = Average then 'On Target'
when T_Points < Average then 'Above Target'
ELSE 'Below Target'
END AS progress, COUNT(progress)
FROM 
(
SELECT Lesson_CLass.*, avg(t_points) over () AS Average
FROM Lesson_CLass GROUP BY progress
) with_avg;

但是,我面对“ group roch”中未知专栏的“进度”

I am trying to use a GROUP BY statement that would count each of the progress grades:

SELECT
with_avg.*, 
CASE
when T_Points = Average then 'On Target'
when T_Points < Average then 'Above Target'
ELSE 'Below Target'
END AS progress, COUNT(progress)
FROM 
(
SELECT Lesson_CLass.*, avg(t_points) over () AS Average
FROM Lesson_CLass GROUP BY progress
) with_avg;

However, I am faced with Unknown column 'progress' in 'GROUP clause'

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

毁梦 2025-02-05 01:58:39

使用以下操作:如果您不需要小组,

select *, COUNT(progress) over() as prccnt
from (
    SELECT
    with_avg.*, 
    CASE
    when T_Points = Average then 'On Target'
    when T_Points < Average then 'Above Target'
    ELSE 'Below Target'
    END AS progress
          FROM 
          (
             SELECT Lesson_CLass.*, avg(t_points) over () AS Average
             FROM Lesson_CLass 
          ) with_avg;
)main

请使用此信息:如果您要组

select *,COUNT(progress) as prccnt
from (
    SELECT
    with_avg.*, 
    CASE
    when T_Points = Average then 'On Target'
    when T_Points < Average then 'Above Target'
    ELSE 'Below Target'
    END AS progress
          FROM 
          (
             SELECT Lesson_CLass.*, avg(t_points) over () AS Average
             FROM Lesson_CLass 
          ) with_avg;
)main
group by [column name]

use this : if you don't need group by

select *, COUNT(progress) over() as prccnt
from (
    SELECT
    with_avg.*, 
    CASE
    when T_Points = Average then 'On Target'
    when T_Points < Average then 'Above Target'
    ELSE 'Below Target'
    END AS progress
          FROM 
          (
             SELECT Lesson_CLass.*, avg(t_points) over () AS Average
             FROM Lesson_CLass 
          ) with_avg;
)main

use this : if you want group by

select *,COUNT(progress) as prccnt
from (
    SELECT
    with_avg.*, 
    CASE
    when T_Points = Average then 'On Target'
    when T_Points < Average then 'Above Target'
    ELSE 'Below Target'
    END AS progress
          FROM 
          (
             SELECT Lesson_CLass.*, avg(t_points) over () AS Average
             FROM Lesson_CLass 
          ) with_avg;
)main
group by [column name]
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文