题目
销售表 Sales
:
产品表 Product
:
编写一个 SQL 查询,选出每个销售产品 第一年 销售的 产品 id、年份、数量 和 价格。
结果表中的条目可以按 任意顺序 排列。
查询结果格式如下例所示:
示例 1:
解题思路
前置知识
MIN() 函数
MIN 函数返回一列中的最小值。NULL 值不包括在计算中。
SELECT MIN(column_name) FROM table_name
注释:MIN 和 MAX 也可用于文本列,以获得按字母顺序排列的最高或最低值。
我们拥有下面这个 "Orders" 表:
O_Id OrderDate OrderPrice Customer 1 2008/12/29 1000 Bush 2 2008/11/23 1600 Carter 3 2008/10/05 700 Bush 4 2008/09/28 300 Bush 5 2008/08/06 2000 Adams 6 2008/07/21 100 Carter 现在,我们希望查找 "OrderPrice" 列的最小值。
我们使用如下 SQL 语句:
SELECT MIN(OrderPrice) AS SmallestOrderPrice FROM Orders
结果集类似这样:
SmallestOrderPrice 100
了解了上述函数后,我们来看一下这道题
1.题目要求我们 选出每个销售产品 第一年 销售的 产品 id、年份、数量 和 价格,我们可以用子查询来解决这个问题。
2.首先我们将 product_id 进行分组,然后利用 min()函数找到 product_id 分组中 year 最小的数据。
3.最后返回product_id 等于子查询查询到的 product_id 即可。
代码实现
select product_id, year as first_year, quantity, price
from sales
where(product_id, year) in(select product_id,min(year) from salesgroup by product_id
)
测试结果