sql语句难题:排序,统计

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