下午好。很高兴发布,我不需要发布任何问题,而是开始回答。呜呜:)
无论如何,我在这里的问题是我正在尝试编写一个子查询来提取我的供应商、他们的部分以及他们的部分是多少。供应商可能会多次提供零件,因此我想平均零件的价格。稍后,我正在寻找针对这些部分的任何问题通知。但是,我无法引用稍后平均的字段。我该怎么办?
该 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上不断收到错误,告诉我这是一个无效的标识符。有人可以帮忙吗?
您应该命名 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
),
. . .