Oracle SQL - AVG函数无效标识符

时间:2017-10-13 19:25:28

标签: sql oracle

下午好。很高兴发帖我没有必要稍微发布任何问题,而是开始回答。哇:))

无论如何,我的问题是我正在尝试编写一个子查询来拉动我的供应商,他们的部分,以及他们的部分是多少。供应商可能会多次供应该零件,因此我希望平均零件的价格。后来,我希望看到针对这些部分的任何问题通知。但是,我无法引用我后来平均的字段。我该怎么办?

SQL如下所示,采用ORACLE语法:

WITH
PartVendor AS
(
SELECT PARTNAME, PARTNUM, AVG(PARTPRICE), VENDNAME, VENDNUM
FROM PARTBL
    INNER JOIN VENDTBL ON VENDNUM = PARTVENDNUM
GROUP BY PARTNAME, PARTNUM, VENDNAME, VENDNUM
),

PartProbs AS
(
SELECT PartVendor.*, PROBNUM, PROBDESC
FROM PartVendor
    INNER JOIN PROBTBL ON PARTNUM = PROBPARTNUM
)

SELECT *
FROM PartProbs

稍后,我会做更多。但我一直在PARTPRICE上收到错误,告诉我这是一个无效的标识符。有人可以帮忙吗?

1 个答案:

答案 0 :(得分:1)

您应该在CTE中命名所有列:

WITH PartVendor AS (
      SELECT PARTNAME, PARTNUM, AVG(PARTPRICE) as AVG_PARTPRICE, VENDNAME, VENDNUM
      FROM PARTBL INNER JOIN
           VENDTBL ON VENDNUM = PARTVENDNUM
      GROUP BY PARTNAME, PARTNUM, VENDNAME, VENDNUM
     ),
     . . .