来自多个子查询的视图 MYSQL
Views from Multiple Subqueries MYSQL
我有一个需要两个子查询的数学代码。下面是代码的副本。
SELECT AVGTEMP_X.Average_Temp, ProduceMonAvg.Avergae_CPI,
SUM(AVGTEMP_X.Average_Temp) as AVGTEMPSUM,
SUM(ProduceMonAvg.Average_CPI) as PROCPISUM,
SUM(AVGTEMP_X.Average_Temp*AVGTEMP_X.Average_Temp) AS AVGTEMPSQ,
SUM(ProduceMonAvg.Average_CPI*ProduceMonAvg.Average_CPI)PROCPISQ,
SUM(AVGTEMP_X.Average_Temp*ProduceMonAvg.Average_CPI) AS PowerSum,
COUNT(*) as COUNT,
(COUNT*(PowerSum)-(AVGTEMPSUM))/(sqrt(COUNT*(AVGTEMPSQ)-pow(AVGTEMPSUM,2)*
(COUNT*(PROCPISQ)-pow(PROCPISUM,2)))) AS Correlation
FROM(SELECT series_id,FORMAT(AVG(value),2) AS Average_CPI, period
FROM CURRENT
WHERE series_id = 'CUSR0000SEFK'
AND theYear >=(1997)
AND theYear <=(2010)
GROUP BY period) AS ProduceMonAvg,
(SELECT Average_Temp
FROM AVGTEMP_X)
INNER JOIN ProduceMonAvg
ON AVGTEMP_X.period = ProduceMonAvg.period
我收到一条错误消息
1146 - Table 'xxx.ProduceMonAvg' doesn't exist
1054 - Unknown column 'COUNT' in 'field list'
在您的外部查询中,您引用 ProdcueMonAvg.Average_CPI
等。在您的内部查询中,您将其别名为 AS ProduceMonAvg
。注意错别字——Prodcue
vs Produce
。你确定你的错误没有说 Table xxx.ProdcueMonAvg doesn't exist
?
就此而言,您的查询还有其他一些问题。您对 AVGTEMP_X 查询的连接使用了一个不需要的子查询,它还执行交叉连接,然后执行内部连接。我怀疑那是你想要的。试试这个:
SELECT AVGTEMP_X.Average_Temp,
ProduceMonAvg.Average_CPI,
SUM(AVGTEMP_X.Average_Temp) AS AVGTEMPSUM,
SUM(ProduceMonAvg.Average_CPI) AS PROCPISUM,
SUM(AVGTEMP_X.Average_Temp * AVGTEMP_X.Average_Temp) AS AVGTEMPSQ,
SUM(ProduceMonAvg.Average_CPI * ProduceMonAvg.Average_CPI) PROCPISQ,
SUM(AVGTEMP_X.Average_Temp * ProduceMonAvg.Average_CPI) AS PowerSum,
COUNT(*) AS TOTAL,
(COUNT(*) * (SUM(AVGTEMP_X.Average_Temp * ProduceMonAvg.Average_CPI)) - (SUM(AVGTEMP_X.Average_Temp))) / (sqrt(COUNT(*)* (SUM(AVGTEMP_X.Average_Temp * AVGTEMP_X.Average_Temp)) - pow(SUM(AVGTEMP_X.Average_Temp), 2) * (COUNT(*)* (SUM(ProduceMonAvg.Average_CPI * ProduceMonAvg.Average_CPI)) - pow(SUM(ProduceMonAvg.Average_CPI), 2)))) AS Correlation
FROM (
SELECT series_id,
FORMAT(AVG(value), 2) AS Average_CPI,
period
FROM CURRENT
WHERE series_id = 'CUSR0000SEFK'
AND theYear >= (1997)
AND theYear <= (2010)
GROUP BY period
) AS ProduceMonAvg
INNER JOIN AVGTEMP_X ON AVGTEMP_X.period = ProduceMonAvg.period
我还创建了一些模拟表和数据并最终测试了查询。它 returns 结果。你可以在这里看到它:http://sqlfiddle.com/#!9/47523/14
我有一个需要两个子查询的数学代码。下面是代码的副本。
SELECT AVGTEMP_X.Average_Temp, ProduceMonAvg.Avergae_CPI,
SUM(AVGTEMP_X.Average_Temp) as AVGTEMPSUM,
SUM(ProduceMonAvg.Average_CPI) as PROCPISUM,
SUM(AVGTEMP_X.Average_Temp*AVGTEMP_X.Average_Temp) AS AVGTEMPSQ,
SUM(ProduceMonAvg.Average_CPI*ProduceMonAvg.Average_CPI)PROCPISQ,
SUM(AVGTEMP_X.Average_Temp*ProduceMonAvg.Average_CPI) AS PowerSum,
COUNT(*) as COUNT,
(COUNT*(PowerSum)-(AVGTEMPSUM))/(sqrt(COUNT*(AVGTEMPSQ)-pow(AVGTEMPSUM,2)*
(COUNT*(PROCPISQ)-pow(PROCPISUM,2)))) AS Correlation
FROM(SELECT series_id,FORMAT(AVG(value),2) AS Average_CPI, period
FROM CURRENT
WHERE series_id = 'CUSR0000SEFK'
AND theYear >=(1997)
AND theYear <=(2010)
GROUP BY period) AS ProduceMonAvg,
(SELECT Average_Temp
FROM AVGTEMP_X)
INNER JOIN ProduceMonAvg
ON AVGTEMP_X.period = ProduceMonAvg.period
我收到一条错误消息
1146 - Table 'xxx.ProduceMonAvg' doesn't exist
1054 - Unknown column 'COUNT' in 'field list'
在您的外部查询中,您引用 ProdcueMonAvg.Average_CPI
等。在您的内部查询中,您将其别名为 AS ProduceMonAvg
。注意错别字——Prodcue
vs Produce
。你确定你的错误没有说 Table xxx.ProdcueMonAvg doesn't exist
?
就此而言,您的查询还有其他一些问题。您对 AVGTEMP_X 查询的连接使用了一个不需要的子查询,它还执行交叉连接,然后执行内部连接。我怀疑那是你想要的。试试这个:
SELECT AVGTEMP_X.Average_Temp,
ProduceMonAvg.Average_CPI,
SUM(AVGTEMP_X.Average_Temp) AS AVGTEMPSUM,
SUM(ProduceMonAvg.Average_CPI) AS PROCPISUM,
SUM(AVGTEMP_X.Average_Temp * AVGTEMP_X.Average_Temp) AS AVGTEMPSQ,
SUM(ProduceMonAvg.Average_CPI * ProduceMonAvg.Average_CPI) PROCPISQ,
SUM(AVGTEMP_X.Average_Temp * ProduceMonAvg.Average_CPI) AS PowerSum,
COUNT(*) AS TOTAL,
(COUNT(*) * (SUM(AVGTEMP_X.Average_Temp * ProduceMonAvg.Average_CPI)) - (SUM(AVGTEMP_X.Average_Temp))) / (sqrt(COUNT(*)* (SUM(AVGTEMP_X.Average_Temp * AVGTEMP_X.Average_Temp)) - pow(SUM(AVGTEMP_X.Average_Temp), 2) * (COUNT(*)* (SUM(ProduceMonAvg.Average_CPI * ProduceMonAvg.Average_CPI)) - pow(SUM(ProduceMonAvg.Average_CPI), 2)))) AS Correlation
FROM (
SELECT series_id,
FORMAT(AVG(value), 2) AS Average_CPI,
period
FROM CURRENT
WHERE series_id = 'CUSR0000SEFK'
AND theYear >= (1997)
AND theYear <= (2010)
GROUP BY period
) AS ProduceMonAvg
INNER JOIN AVGTEMP_X ON AVGTEMP_X.period = ProduceMonAvg.period
我还创建了一些模拟表和数据并最终测试了查询。它 returns 结果。你可以在这里看到它:http://sqlfiddle.com/#!9/47523/14