我有下面的代碼,Teradata將無法正常工作,並以「選定的非聚合值必須是關聯組的一部分」的形式返回消息。我想我已經確保所有非聚合字段已經放入GROUP BY子句中。你能幫我看看爲什麼它不起作用嗎?Teradata SQL與GROUP BY中的非聚合字段
SELECT str.store,str.city, str.state, dep.deptdesc, 100*(Clean.DecSales/Clean.DecSaleDays-Clean.NovSales/Clean.NovSaleDays)/(Clean.NovSales/Clean.NovSaleDays) AS PercentageChange
FROM ((skuinfo sku LEFT JOIN deptinfo dep ON sku.dept=dep.dept)
LEFT JOIN
(SELECT t.sku, t.store, COUNT(DISTINCT t.saledate) AS NumOfDays, SUM(t.amt) AS DailyTotal,
(CAST(EXTRACT(YEAR FROM t.saledate) AS VARCHAR(8)))||'.'||
(CAST(EXTRACT(MONTH FROM t.saledate) AS VARCHAR(8)))||'.'||
(CAST(t.store AS VARCHAR(8)))AS ComboID,
SUM(CASE WHEN EXTRACT(MONTH from t.saledate) =11 THEN t.Amt END) AS NovSales,
SUM(CASE WHEN EXTRACT(MONTH from t.saledate) =12 THEN t.Amt END) AS DecSales,
COUNT(CASE WHEN EXTRACT(MONTH from t.saledate) =11 THEN t.saledate END) AS NovSaleDays,
COUNT(CASE WHEN EXTRACT(MONTH from t.saledate) =12 THEN t.saledate END) AS DecSaleDays
FROM trnsact t
WHERE (t.saledate NOT BETWEEN '2005-08-01' AND '2005-08-31') AND t.stype='P'
GROUP BY t.sku, t.store
HAVING NumOfDays>19) Clean
ON sku.sku=Clean.sku)
LEFT JOIN strinfo str ON str.store=Clean.store
GROUP BY str.store,str.city, str.state, dep.deptdesc;
將表達式PercentageChange放入SUM中或放入GROUP BY中。 – Mihai