题解 | #有取消订单记录的司机平均评分#

有取消订单记录的司机平均评分

https://www.nowcoder.com/practice/f022c9ec81044d4bb7e0711ab794531a

WITH t1 as( -- 找到所有的有取消订单的司机和所有评分
    SELECT
       driver_id,
       grade
FROM tb_get_car_order
WHERE driver_id
IN (select driver_id -- 找到所有的有取消订单的司机id
    FROM tb_get_car_order
    WHERE fare IS NULL) AND fare IS NOT NULL
    order by order_id
),t2 as( -- 找到所求司机对应的评分分别求和并分别统计数量
    SELECT
       driver_id,
       sum(grade) OVER(PARTITION BY driver_id) fk_s,
       sum(grade) OVER() z_s,
       count(driver_id) OVER(PARTITION BY driver_id) fk_cnt,
       count(driver_id) OVER() z_cnt
    FROM t1
)

SELECT -- 按题目要求计算用union合并输出
       DISTINCT driver_id,
       round(fk_s/fk_cnt,1) avg_grade
FROM t2
UNION
SELECT
       DISTINCT '总体',
       round(z_s/z_cnt,1) avg_grade
FROM t2

全部评论

相关推荐

03-12 09:57
软件测试
程序员小白条:1)确定测试,测开的方向,技术栈不能写这么少 2)课程凑数的,不是99,100分没必要写 3)实习经历这块要有突出的不是劳动性质的亮点,自己设计的什么方案,什么自动化?什么提效工具?不是一些边角料,人云亦云的东西,没吸引力 4) 校园经历纯没用 5)尽量少写减分项
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务