SQL - 显示平均价格的最小值

时间:2016-06-26 21:34:52

标签: sql average min

我的数据库包含产品和完成列表。我已经能够成功平均每个完成选项的价格,但我只想显示价格最低的选项。

以下是我的数据示例。

表1 - product_t

ProductID   ProductLineID   ProductDescription  ProductFinish   ProductStandardPrice    ProductOnHand
1   1   "Cherry End Table"  Cherry  175.00  0
2   1   "Birch Coffee Tables"   Birch   200.00  0
3   1   "Oak Computer Desk" Oak 750.00  0
4   1   "Entertainment Center"  Cherry  1650.00 0

此查询会生成每个可用产品完成列表以及已完成项目的平均价格。

SELECT ProductFinish, AVG(ProductStandardPrice) as AveragePrice
FROM product_t
WHERE ProductFinish IS NOT NULL
GROUP BY ProductFinish;

但是,我只想显示此查询产生的最低价格。我尝试了这个查询,但它不会执行。

 SELECT ProductFinish, MIN (AVG(ProductStandardPrice)) as AveragePrice
 FROM product_t
 WHERE ProductFinish IS NOT NULL
 GROUP BY ProductFinish;

提前感谢您的帮助。非常感谢。

1 个答案:

答案 0 :(得分:3)

获得最低值的典型方法是使用order by并对行数进行某种限制。在ANSI标准SQL中,这将是:

SELECT ProductFinish, AVG(ProductStandardPrice) as AveragePrice
FROM product_t
WHERE ProductFinish IS NOT NULL
GROUP BY ProductFinish;
ORDER BY AveragePrice ASC
FETCH FIRST 1 ROW ONLY;

请注意,某些数据库使用LIMIT 1TOP 1而不是FETCH FIRST 1 ROW ONLY。此外,此版本仅提取一个价格最低的记录。如果存在重复的最小值,则选择任意值。