sql语句难题:排序,统计
问题描述:
本人想要实现某产品的销量统计,算法如下:
前两天的销量比较:如果前天比昨天高,则标记为正1;低,则标记为负1;
若持平,则标记为0. 并且按销量由高到低排序。
求高手一条sql语句解决(多条也行)。
已知条件:
表名:goods, 商品名:goodsname,交易时间:goodstime,销量:saleamount.
其中,商品有20种,记录估计1000条。
说明:只求sql,不用考虑其他sql语句以外的问题。
答
select
goodsname,
goodstime,
saleamount curr_saleamount,
lag(saleamount, 1) over (order by goodstime) prev_saleamount
from goods;
lag函数可以取到上个月的 saleamount 然后再写个子查询比较即可 第一个月的是null