leetcode中数据库第262题利用临时表解决用户行程与取消率的问题

想法就是去创建临时表而不是去做连接,来提高数据查询速度,因为当一个查询涉及很多表时,查询的笛卡尔积是非常大的,单纯的用索引可能解决不了查询时间的问题.这个时候可以用临时表,将一个查询分成多步完成,减少输出查询结果时的笛卡尔积,会对提高查询效率有很大的帮助(这句话是教材里面的)
先要筛选出满足条件的临时表,再去计算取消率,这道题的想法是套用了双重临时表

select 
	Request_at Day,
	round(count(case status when 'completed' then null else status end) / count(status),2) as 'Cancellation Rate' 
from 
    (select 
        `status`, request_at 
	from trips
    where
        client_id  not in (select users_id from users where banned = 'Yes')
     and 
        driver_id  not in (select users_id from users where banned = 'Yes')
	) 
where Request_at >= '2013-10-01'
and Request_at <= '2013-10-03'
group by request_at;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值