用 SQL计算一支股票最长连续上涨了多少天?

  • 这是润乾公司的招聘考题,通过率不足 20%;因为太难,后来被改成另一种方式:把 SQL 语句写出来让应聘者解释它在算什么,通过率依然不高。
select max (consecutive_day)from (select count(*) (consecutive_day  from (select sum(rise_mark) over(order by trade_date) days_no_gain    from (select trade_date,        case when closing_price>lag(closing_price) over(order by trade_date)               then 0 else 1 END rise_mark       from stock_price ) )   group by days\_no\_gain)

用 SQL 写出来 1 亿条数据中取前 10 名

SELECT TOP 10 x FROM T ORDER BY x DESC

 这个语句对应的执行逻辑是先对所有数据进行大排序,然后再取出前 10 个,后面的不要了。排序是一个很慢的动作,会多次遍历数据,如果数据量大到内存装不下,那还需要外存做缓存,性能还会进一步急剧下降。如果严格按这句 SQL 体现的逻辑去执行,这个运算无论如何是跑不快的。然而,很多程序员都知道这个运算并不需要大排序,也用不着外存缓存,一次遍历用一点点内存就可以完成,也就是存在更高性能的算法。可惜的是,用 SQL 却写不出这样的算法,只能寄希望于数据库的优化器足够聪明,能把这句 SQL 转换成高性能算法执行,但情况复杂时数据库的优化器也未必靠谱。

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值