• 数据库系统原理与应用教程(078)—— MySQL 练习题:操作题 173-180(二十二):综合练习


    数据库系统原理与应用教程(078)—— MySQL 练习题:操作题 173-180(二十二):综合练习

    173、分组统计查询(1)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_user_log;
    CREATE TABLE tb_user_log (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        uid INT NOT NULL COMMENT '用户ID',
        artical_id INT NOT NULL COMMENT '视频ID',
        in_time datetime COMMENT '进入时间',
        out_time datetime COMMENT '离开时间',
        sign_in TINYINT DEFAULT 0 COMMENT '是否签到'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_user_log(uid, artical_id, in_time, out_time, sign_in) VALUES
      (101, 9001, '2021-11-01 10:00:00', '2021-11-01 10:00:31', 0),
      (102, 9001, '2021-11-01 10:00:00', '2021-11-01 10:00:24', 0),
      (102, 9002, '2021-11-01 11:00:00', '2021-11-01 11:00:11', 0),
      (101, 9001, '2021-11-02 10:00:00', '2021-11-02 10:00:50', 0),
      (102, 9002, '2021-11-02 11:00:01', '2021-11-02 11:00:24', 0);
    */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    用户行为日志表:tb_user_log(uid-用户ID,artical_id-文章ID,in_time-进入时间,out_time-离开时间,sign_in-是否签到),表中数据如下:

    mysql> select * from tb_user_log;
    +----+-----+------------+---------------------+---------------------+---------+
    | id | uid | artical_id | in_time             | out_time            | sign_in |
    +----+-----+------------+---------------------+---------------------+---------+
    |  1 | 101 |       9001 | 2021-11-01 10:00:00 | 2021-11-01 10:00:31 |       0 |
    |  2 | 102 |       9001 | 2021-11-01 10:00:00 | 2021-11-01 10:00:24 |       0 |
    |  3 | 102 |       9002 | 2021-11-01 11:00:00 | 2021-11-01 11:00:11 |       0 |
    |  4 | 101 |       9001 | 2021-11-02 10:00:00 | 2021-11-02 10:00:50 |       0 |
    |  5 | 102 |       9002 | 2021-11-02 11:00:01 | 2021-11-02 11:00:24 |       0 |
    +----+-----+------------+---------------------+---------------------+---------+
    5 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    说明:artical_id-文章ID 代表用户浏览的文章的ID,artical_id-文章ID 为 0 表示用户在非文章内容页(比如 App 内的列表页、活动页等)。

    【问题】统计 2021 年 11 月每天的人均浏览文章时长(秒数),结果保留 1 位小数,并按时长由短到长排序。查询结果如下:

    dtavg_viiew_len_sec
    2021-11-0133.0
    2021-11-0236.5

    解答:

    /*
    select date(in_time) dt,
           round(sum(left(timediff(out_time, in_time), 2) * 3600 +  
                     substr(timediff(out_time, in_time), 4, 2) * 60 +
                     right(timediff(out_time, in_time),2)) / count(distinct uid), 1) 
           avg_viiew_len_sec
    from tb_user_log
    where in_time between '2021-11-01 0:0:0' and '2021-11-30 23:59:59'
    group by dt
    order by avg_viiew_len_sec;
    */
    mysql> select date(in_time) dt,
        ->        round(sum(left(timediff(out_time, in_time), 2) * 3600 +  
        ->                  substr(timediff(out_time, in_time), 4, 2) * 60 +
        ->                  right(timediff(out_time, in_time),2)) / count(distinct uid), 1) 
        ->        avg_viiew_len_sec
        -> from tb_user_log
        -> where in_time between '2021-11-01 0:0:0' and '2021-11-30 23:59:59'
        -> group by dt
        -> order by avg_viiew_len_sec;
    +------------+-------------------+
    | dt         | avg_viiew_len_sec |
    +------------+-------------------+
    | 2021-11-01 |              33.0 |
    | 2021-11-02 |              36.5 |
    +------------+-------------------+
    2 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    174、分组统计查询(2)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_order_overall;
    CREATE TABLE tb_order_overall (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        uid INT NOT NULL COMMENT '用户ID',
        event_time datetime COMMENT '下单时间',
        total_amount DECIMAL NOT NULL COMMENT '订单总金额',
        total_cnt INT NOT NULL COMMENT '订单商品总件数',
        `status` TINYINT NOT NULL COMMENT '订单状态'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_order_overall(order_id, uid, event_time, total_amount, total_cnt, `status`) VALUES
      (301001, 101, '2021-10-01 10:00:00', 15900, 2, 1),
      (301002, 101, '2021-10-01 11:00:00', 15900, 2, 1),
      (301003, 102, '2021-10-02 10:00:00', 34500, 8, 0),
      (301004, 103, '2021-10-12 10:00:00', 43500, 9, 1),
      (301005, 105, '2021-11-01 10:00:00', 31900, 7, 1),
      (301006, 102, '2021-11-02 10:00:00', 24500, 6, 1),
      (391007, 102, '2021-11-03 10:00:00', -24500, 6, 2),
      (301008, 104, '2021-11-04 10:00:00', 55500, 12, 0);
      */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    现有订单总表:tb_order_overall(order_id-订单号,uid-用户ID,event_time-下单时间,total_amount-订单总金额, total_cnt-订单商品总件数,status-订单状态),表中数据如下:

    mysql> select * from tb_order_overall;
    +----+----------+-----+---------------------+--------------+-----------+--------+
    | id | order_id | uid | event_time          | total_amount | total_cnt | status |
    +----+----------+-----+---------------------+--------------+-----------+--------+
    |  1 |   301001 | 101 | 2021-10-01 10:00:00 |        15900 |         2 |      1 |
    |  2 |   301002 | 101 | 2021-10-01 11:00:00 |        15900 |         2 |      1 |
    |  3 |   301003 | 102 | 2021-10-02 10:00:00 |        34500 |         8 |      0 |
    |  4 |   301004 | 103 | 2021-10-12 10:00:00 |        43500 |         9 |      1 |
    |  5 |   301005 | 105 | 2021-11-01 10:00:00 |        31900 |         7 |      1 |
    |  6 |   301006 | 102 | 2021-11-02 10:00:00 |        24500 |         6 |      1 |
    |  7 |   391007 | 102 | 2021-11-03 10:00:00 |       -24500 |         6 |      2 |
    |  8 |   301008 | 104 | 2021-11-04 10:00:00 |        55500 |        12 |      0 |
    +----+----------+-----+---------------------+--------------+-----------+--------+
    8 rows in set (0.04 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    说明:

    (1)用户将购物车中多件商品一起下单时,订单总表会生成一个订单(但此时未付款,status-订单状态为 0,表示待付款);

    (2)当用户支付完成时,在订单总表修改对应订单记录的 status-订单状态为 1,表示已付款;

    (3)若用户退货退款,在订单总表生成一条交易总金额为负值的记录(表示退款金额,订单号为退款单号,status-订单状态为 2 表示已退款)。

    【问题】请计算商城中 2021 年每月的 GMV,输出 GMV 大于 10w 的每月 GMV,值保留到整数。结果按 GMV 升序排序。查询结果如下:

    monthGMV
    2021-10109800
    2021-11111900

    解答:

    /*
    select concat(left(event_time, 4), '-', substr(event_time, 6, 2)) month,
           sum(total_amount) GMV
    from tb_order_overall
    where event_time between '2021-01-01 00:00:00' and '2021-12-31 23:59:59'
          and status in (0, 1)
    group by month
    having GMV > 100000
    order by GMV;
    */
    mysql> select concat(left(event_time, 4), '-', substr(event_time, 6, 2)) month,
        ->        sum(total_amount) GMV
        -> from tb_order_overall
        -> where event_time between '2021-01-01 00:00:00' and '2021-12-31 23:59:59'
        ->       and status in (0, 1)
        -> group by month
        -> having GMV > 100000
        -> order by GMV;
    +---------+--------+
    | month   | GMV    |
    +---------+--------+
    | 2021-10 | 109800 |
    | 2021-11 | 111900 |
    +---------+--------+
    2 rows in set (0.03 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    175、分组统计查询(3)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_user_event;
    CREATE TABLE tb_user_event (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        uid INT NOT NULL COMMENT '用户ID',
        product_id INT NOT NULL COMMENT '商品ID',
        event_time datetime COMMENT '行为时间',
        if_click TINYINT COMMENT '是否点击',
        if_cart TINYINT COMMENT '是否加购物车',
        if_payment TINYINT COMMENT '是否付款',
        if_refund TINYINT COMMENT '是否退货退款'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_user_event(uid, product_id, event_time, if_click, if_cart, if_payment, if_refund) VALUES
      (101, 8001, '2021-10-01 10:00:00', 0, 0, 0, 0),
      (102, 8001, '2021-10-01 10:00:00', 1, 0, 0, 0),
      (103, 8001, '2021-10-01 10:00:00', 1, 1, 0, 0),
      (104, 8001, '2021-10-02 10:00:00', 1, 1, 1, 0),
      (105, 8001, '2021-10-02 10:00:00', 1, 1, 1, 0),
      (101, 8002, '2021-10-03 10:00:00', 1, 1, 1, 0),
      (109, 8001, '2021-10-04 10:00:00', 1, 1, 1, 1);
    */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    商品行为表:tb_user_event(uid-用户ID,product_id-商品ID,event_time-行为时间,if_click-是否点击,if_cart-是否加购物车,if_payment-是否付款,if_refund-是否退货退款),表中数据如下:

    mysql> select * from tb_user_event;
    +----+-----+------------+---------------------+----------+---------+------------+-----------+
    | id | uid | product_id | event_time          | if_click | if_cart | if_payment | if_refund |
    +----+-----+------------+---------------------+----------+---------+------------+-----------+
    |  1 | 101 |       8001 | 2021-10-01 10:00:00 |        0 |       0 |          0 |         0 |
    |  2 | 102 |       8001 | 2021-10-01 10:00:00 |        1 |       0 |          0 |         0 |
    |  3 | 103 |       8001 | 2021-10-01 10:00:00 |        1 |       1 |          0 |         0 |
    |  4 | 104 |       8001 | 2021-10-02 10:00:00 |        1 |       1 |          1 |         0 |
    |  5 | 105 |       8001 | 2021-10-02 10:00:00 |        1 |       1 |          1 |         0 |
    |  6 | 101 |       8002 | 2021-10-03 10:00:00 |        1 |       1 |          1 |         0 |
    |  7 | 109 |       8001 | 2021-10-04 10:00:00 |        1 |       1 |          1 |         1 |
    +----+-----+------------+---------------------+----------+---------+------------+-----------+
    7 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    【问题】请统计 2021 年 10 月每个有展示记录的退货率不大于 0.5 的商品各项指标(商品点展比,加购率,成单率,退货率),当分母为 0 时整体结果记为0,结果中各项指标保留3位小数,并按商品ID升序排序。查询结果如下:

    说明:

    (1)商品点展比 = 点击数 ÷ 展示数;

    (2)加购率 = 加购数 ÷ 点击数;

    (3)成单率 = 付款数 ÷ 加购数;

    (4)退货率 = 退款数 ÷ 付款数。

    product_idctrcart_ratepayment_raterefund_rate
    80010.8330.8000.7500.333
    80021.0001.0001.0000.000

    解答:

    /*
    select product_id, round(sum(if_click)/count(*), 3) ctr,
           round(sum(if_cart)/sum(if_click), 3) cart_rate,
           round(sum(if_payment)/sum(if_cart), 3) payment_rate,
           round(sum(if_refund)/sum(if_payment), 3) refund_rate
    from tb_user_event
    where event_time between '2021-10-01 00:00:00' and '2021-10-31 23:59:59'
    group by product_id
    order by product_id;
    */
    mysql> select product_id, round(sum(if_click)/count(*), 3) ctr,
        ->        round(sum(if_cart)/sum(if_click), 3) cart_rate,
        ->        round(sum(if_payment)/sum(if_cart), 3) payment_rate,
        ->        round(sum(if_refund)/sum(if_payment), 3) refund_rate
        -> from tb_user_event
        -> where event_time between '2021-10-01 00:00:00' and '2021-10-31 23:59:59'
        -> group by product_id
        -> order by product_id;
    +------------+-------+-----------+--------------+-------------+
    | product_id | ctr   | cart_rate | payment_rate | refund_rate |
    +------------+-------+-----------+--------------+-------------+
    |       8001 | 0.833 |     0.800 |        0.750 |       0.333 |
    |       8002 | 1.000 |     1.000 |        1.000 |       0.000 |
    +------------+-------+-----------+--------------+-------------+
    2 rows in set (0.04 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25

    175、分组统计查询(3)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_order_overall;
    CREATE TABLE tb_order_overall (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        uid INT NOT NULL COMMENT '用户ID',
        event_time datetime COMMENT '下单时间',
        total_amount DECIMAL NOT NULL COMMENT '订单总金额',
        total_cnt INT NOT NULL COMMENT '订单商品总件数',
        `status` TINYINT NOT NULL COMMENT '订单状态'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_order_overall(order_id, uid, event_time, total_amount, total_cnt, `status`) VALUES
      (301001, 101, '2021-10-01 10:00:00', 30000, 3, 1),
      (301002, 102, '2021-10-01 11:00:00', 23900, 2, 1),
      (301003, 103, '2021-10-02 10:00:00', 31000, 2, 1);
    
    DROP TABLE IF EXISTS tb_product_info;
    CREATE TABLE tb_product_info (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        product_id INT NOT NULL COMMENT '商品ID',
        shop_id INT NOT NULL COMMENT '店铺ID',
        tag VARCHAR(12) COMMENT '商品类别标签',
        in_price DECIMAL NOT NULL COMMENT '进货价格',
        quantity INT NOT NULL COMMENT '进货数量',
        release_time datetime COMMENT '上架时间'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    DROP TABLE IF EXISTS tb_order_detail;
    CREATE TABLE tb_order_detail (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        product_id INT NOT NULL COMMENT '商品ID',
        price DECIMAL NOT NULL COMMENT '商品单价',
        cnt INT NOT NULL COMMENT '下单数量'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_product_info(product_id, shop_id, tag, in_price, quantity, release_time) VALUES
      (8001, 901, '家电', 6000, 100, '2020-01-01 10:00:00'),
      (8002, 902, '家电', 12000, 50, '2020-01-01 10:00:00'),
      (8003, 901, '3C数码', 12000, 50, '2020-01-01 10:00:00');
    
    INSERT INTO tb_order_detail(order_id, product_id, price, cnt) VALUES
      (301001, 8001, 8500, 2),
      (301001, 8002, 15000, 1),
      (301002, 8001, 8500, 1),
      (301002, 8002, 16000, 1),
      (301003, 8002, 14000, 1),
      (301003, 8003, 18000, 1);
    */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50

    商品信息表:tb_product_info(product_id-商品ID,shop_id-店铺ID,tag-商品类别标签,in_price-进货价格,quantity-进货数量,release_time-上架时间),表中数据如下:

    mysql> select * from tb_product_info;
    +----+------------+---------+----------+----------+----------+---------------------+
    | id | product_id | shop_id | tag      | in_price | quantity | release_time        |
    +----+------------+---------+----------+----------+----------+---------------------+
    |  1 |       8001 |     901 | 家电     |     6000 |      100 | 2020-01-01 10:00:00 |
    |  2 |       8002 |     902 | 家电     |    12000 |       50 | 2020-01-01 10:00:00 |
    |  3 |       8003 |     901 | 3C数码   |    12000 |       50 | 2020-01-01 10:00:00 |
    +----+------------+---------+----------+----------+----------+---------------------+
    3 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    订单总表:tb_order_overall(order_id-订单号,uid-用户ID,event_time-下单时间,total_amount-订单总金额,total_cnt-订单商品总件数,status-订单状态),表中数据如下:

    mysql> select * from tb_order_overall;
    +----+----------+-----+---------------------+--------------+-----------+--------+
    | id | order_id | uid | event_time          | total_amount | total_cnt | status |
    +----+----------+-----+---------------------+--------------+-----------+--------+
    |  1 |   301001 | 101 | 2021-10-01 10:00:00 |        30000 |         3 |      1 |
    |  2 |   301002 | 102 | 2021-10-01 11:00:00 |        23900 |         2 |      1 |
    |  3 |   301003 | 103 | 2021-10-02 10:00:00 |        31000 |         2 |      1 |
    +----+----------+-----+---------------------+--------------+-----------+--------+
    3 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    订单明细表:tb_order_detail(order_id-订单号,product_id-商品ID,price-商品单价,cnt-下单数量),表中数据如下:

    mysql> select * from tb_order_detail;
    +----+----------+------------+-------+-----+
    | id | order_id | product_id | price | cnt |
    +----+----------+------------+-------+-----+
    |  1 |   301001 |       8001 |  8500 |   2 |
    |  2 |   301001 |       8002 | 15000 |   1 |
    |  3 |   301002 |       8001 |  8500 |   1 |
    |  4 |   301002 |       8002 | 16000 |   1 |
    |  5 |   301003 |       8002 | 14000 |   1 |
    |  6 |   301003 |       8003 | 18000 |   1 |
    +----+----------+------------+-------+-----+
    6 rows in set (0.02 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    【问题】请计算 2021 年 10 月以来店铺 901 中商品毛利率大于 24.9% 的商品信息及店铺整体毛利率。结果先输出店铺毛利率,再按商品 ID 升序输出各商品毛利率,均保留 1 位小数。查询结果如下:

    说明:

    (1)商品毛利率 = (1-进价/平均单件售价) * 100%;

    (2)店铺毛利率 = (1-总进价成本/总销售收入) * 100%。

    product_idprofit_rate
    店铺汇总31.0%
    800129.4%
    800333.3%

    解答:

    /*
    select '店铺汇总' product_id,
           concat(round((1 - sum(pi.in_price * od.cnt)/sum(od.price * od.cnt)) * 100, 1),'%') 
           profit_rate 
    from tb_product_info pi join tb_order_detail od
         on pi.product_id = od.product_id
    where pi.shop_id = '901' and od.order_id in
         (select order_id from tb_order_overall where event_time >= '2021-10-01 00:00:00')
    union     
    select pi.product_id,
           concat(round((1 - pi.in_price/(sum(od.price * od.cnt)/sum(od.cnt))) * 100, 1), '%')
           profit_rate 
    from tb_product_info pi join tb_order_detail od
         on pi.product_id = od.product_id
    where pi.shop_id = '901' and od.order_id in
         (select order_id from tb_order_overall where event_time >= '2021-10-01 00:00:00')
    group by pi.product_id,pi.in_price;
    */
    mysql> select '店铺汇总' product_id,
        ->        concat(round((1 - sum(pi.in_price * od.cnt)/sum(od.price * od.cnt)) * 100, 1),'%') 
        ->        profit_rate 
        -> from tb_product_info pi join tb_order_detail od
        ->      on pi.product_id = od.product_id
        -> where pi.shop_id = '901' and od.order_id in
        ->      (select order_id from tb_order_overall where event_time >= '2021-10-01 00:00:00')
        -> union     
        -> select pi.product_id,
        ->        concat(round((1 - pi.in_price/(sum(od.price * od.cnt)/sum(od.cnt))) * 100, 1), '%')
        ->        profit_rate 
        -> from tb_product_info pi join tb_order_detail od
        ->      on pi.product_id = od.product_id
        -> where pi.shop_id = '901' and od.order_id in
        ->      (select order_id from tb_order_overall where event_time >= '2021-10-01 00:00:00')
        -> group by pi.product_id,pi.in_price
        -> order by product_id;
    +--------------+-------------+
    | product_id   | profit_rate |
    +--------------+-------------+
    | 8001         | 29.4%       |
    | 8003         | 33.3%       |
    | 店铺汇总     | 31.0%       |
    +--------------+-------------+
    3 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43

    176、分组统计查询(4)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_order_overall;
    CREATE TABLE tb_order_overall (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        uid INT NOT NULL COMMENT '用户ID',
        event_time datetime COMMENT '下单时间',
        total_amount DECIMAL NOT NULL COMMENT '订单总金额',
        total_cnt INT NOT NULL COMMENT '订单商品总件数',
        `status` TINYINT NOT NULL COMMENT '订单状态'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    DROP TABLE IF EXISTS tb_product_info;
    CREATE TABLE tb_product_info (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        product_id INT NOT NULL COMMENT '商品ID',
        shop_id INT NOT NULL COMMENT '店铺ID',
        tag VARCHAR(12) COMMENT '商品类别标签',
        in_price DECIMAL NOT NULL COMMENT '进货价格',
        quantity INT NOT NULL COMMENT '进货数量',
        release_time datetime COMMENT '上架时间'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    DROP TABLE IF EXISTS tb_order_detail;
    CREATE TABLE tb_order_detail (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        product_id INT NOT NULL COMMENT '商品ID',
        price DECIMAL NOT NULL COMMENT '商品单价',
        cnt INT NOT NULL COMMENT '下单数量'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_product_info(product_id, shop_id, tag, in_price, quantity, release_time) VALUES
      (8001, 901, '零食', 60, 1000, '2020-01-01 10:00:00'),
      (8002, 901, '零食', 140, 500, '2020-01-01 10:00:00'),
      (8003, 901, '零食', 160, 500, '2020-01-01 10:00:00');
    
    INSERT INTO tb_order_overall(order_id, uid, event_time, total_amount, total_cnt, `status`) VALUES
      (301001, 101, '2021-09-30 10:00:00', 140, 1, 1),
      (301002, 102, '2021-10-01 11:00:00', 235, 2, 1),
      (301011, 102, '2021-10-31 11:00:00', 250, 2, 1),
      (301003, 101, '2021-11-02 10:00:00', 300, 2, 1),
      (301013, 105, '2021-11-02 10:00:00', 300, 2, 1),
      (301005, 104, '2021-11-03 10:00:00', 170, 1, 1);
    
    INSERT INTO tb_order_detail(order_id, product_id, price, cnt) VALUES
      (301001, 8002, 150, 1),
      (301011, 8003, 200, 1),
      (301011, 8001, 80, 1),
      (301002, 8001, 85, 1),
      (301002, 8003, 180, 1),
      (301003, 8002, 140, 1),
      (301003, 8003, 180, 1),
      (301013, 8002, 140, 2),
      (301005, 8003, 180, 1);
      */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56

    商品信息表:tb_product_info(product_id-商品ID,shop_id-店铺ID,tag-商品类别标签,in_price-进货价格,quantity-进货数量,release_time-上架时间),表中数据如下:

    mysql> select * from tb_product_info;
    +----+------------+---------+--------+----------+----------+---------------------+
    | id | product_id | shop_id | tag    | in_price | quantity | release_time        |
    +----+------------+---------+--------+----------+----------+---------------------+
    |  1 |       8001 |     901 | 零食   |       60 |     1000 | 2020-01-01 10:00:00 |
    |  2 |       8002 |     901 | 零食   |      140 |      500 | 2020-01-01 10:00:00 |
    |  3 |       8003 |     901 | 零食   |      160 |      500 | 2020-01-01 10:00:00 |
    +----+------------+---------+--------+----------+----------+---------------------+
    3 rows in set (0.01 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    订单总表:tb_order_overall(order_id-订单号,uid-用户ID,event_time-下单时间,total_amount-订单总金额,total_cnt-订单商品总件数,status-订单状态),表中数据如下:

    mysql> select * from tb_order_overall;
    +----+----------+-----+---------------------+--------------+-----------+--------+
    | id | order_id | uid | event_time          | total_amount | total_cnt | status |
    +----+----------+-----+---------------------+--------------+-----------+--------+
    |  1 |   301001 | 101 | 2021-09-30 10:00:00 |          140 |         1 |      1 |
    |  2 |   301002 | 102 | 2021-10-01 11:00:00 |          235 |         2 |      1 |
    |  3 |   301011 | 102 | 2021-10-31 11:00:00 |          250 |         2 |      1 |
    |  4 |   301003 | 101 | 2021-11-02 10:00:00 |          300 |         2 |      1 |
    |  5 |   301013 | 105 | 2021-11-02 10:00:00 |          300 |         2 |      1 |
    |  6 |   301005 | 104 | 2021-11-03 10:00:00 |          170 |         1 |      1 |
    +----+----------+-----+---------------------+--------------+-----------+--------+
    6 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    订单明细表:tb_order_detail(order_id-订单号,product_id-商品ID,price-商品单价,cnt-下单数量),表中数据如下:

    mysql> select * from tb_order_detail;
    +----+----------+------------+-------+-----+
    | id | order_id | product_id | price | cnt |
    +----+----------+------------+-------+-----+
    |  1 |   301001 |       8002 |   150 |   1 |
    |  2 |   301011 |       8003 |   200 |   1 |
    |  3 |   301011 |       8001 |    80 |   1 |
    |  4 |   301002 |       8001 |    85 |   1 |
    |  5 |   301002 |       8003 |   180 |   1 |
    |  6 |   301003 |       8002 |   140 |   1 |
    |  7 |   301003 |       8003 |   180 |   1 |
    |  8 |   301013 |       8002 |   140 |   2 |
    |  9 |   301005 |       8003 |   180 |   1 |
    +----+----------+------------+-------+-----+
    9 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    【问题】请统计零食类商品中复购率 top3 高的商品。结果中复购率保留3位小数,并按复购率倒序、商品ID升序排序。查询结果如下:

    说明:

    (1)复购率指用户在一段时间内对某商品的重复购买比例,复购率越大,则反映出消费者对品牌的忠诚度就越高,也叫回头率。

    (2)某商品复购率 = 近90天内购买它至少两次的人数 ÷ 购买它的总人数

    (3)近 90 天指包含最大日期(记为当天)在内的近 90 天。

    product_idrepurchase_rate
    80011.000
    80020.500
    80030.333

    解答:

    /*
    select a.product_id, round(colB / colA, 3) repurchase_rate
    from 
    (select od.product_id,
           count(distinct uid) colA
    from tb_order_overall oo join tb_order_detail od
    on oo.order_id = od.order_id
    where oo.event_time >=
          (select adddate(max(event_time), -89) from tb_order_overall) and
          od.product_id in
          (select product_id from tb_product_info where tag = '零食')
    group by od.product_id) a
    join 
    (select product_id, count(*) colB
    from (select od.product_id, oo.uid, count(*) aa
          from tb_order_overall oo join tb_order_detail od
          on oo.order_id = od.order_id
          where oo.event_time >=
              (select adddate(max(event_time), -89) from tb_order_overall) and
               od.product_id in
              (select product_id from tb_product_info where tag = '零食')
          group by od.product_id, oo.uid
          having aa > 1) bb
    group by product_id) b
    on a.product_id = b.product_id
    order by repurchase_rate desc, a.product_id;
    */
    mysql> select a.product_id, round(colB / colA, 3) repurchase_rate
        -> from 
        -> (select od.product_id,
        ->        count(distinct uid) colA
        -> from tb_order_overall oo join tb_order_detail od
        -> on oo.order_id = od.order_id
        -> where oo.event_time >=
        ->       (select adddate(max(event_time), -89) from tb_order_overall) and
        ->       od.product_id in
        ->       (select product_id from tb_product_info where tag = '零食')
        -> group by od.product_id) a
        -> join 
        -> (select product_id, count(*) colB
        -> from (select od.product_id, oo.uid, count(*) aa
        ->       from tb_order_overall oo join tb_order_detail od
        ->       on oo.order_id = od.order_id
        ->       where oo.event_time >=
        ->           (select adddate(max(event_time), -89) from tb_order_overall) and
        ->            od.product_id in
        ->           (select product_id from tb_product_info where tag = '零食')
        ->       group by od.product_id, oo.uid
        ->       having aa > 1) bb
        -> group by product_id) b
        -> on a.product_id = b.product_id
        -> order by repurchase_rate desc, a.product_id;
    +------------+-----------------+
    | product_id | repurchase_rate |
    +------------+-----------------+
    |       8001 |           1.000 |
    |       8002 |           0.500 |
    |       8003 |           0.333 |
    +------------+-----------------+
    3 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60

    177、分组统计查询(5)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_get_car_record,tb_get_car_order;
    CREATE TABLE tb_get_car_record (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        uid INT NOT NULL COMMENT '用户ID',
        city VARCHAR(10) NOT NULL COMMENT '城市',
        event_time datetime COMMENT '打车时间',
        end_time datetime COMMENT '打车结束时间',
        order_id INT COMMENT '订单号'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    CREATE TABLE tb_get_car_order (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        uid INT NOT NULL COMMENT '用户ID',
        driver_id INT NOT NULL COMMENT '司机ID',
        order_time datetime COMMENT '接单时间',
        start_time datetime COMMENT '开始计费的上车时间',
        finish_time datetime COMMENT '订单结束时间',
        mileage DOUBLE COMMENT '行驶里程数',
        fare DOUBLE COMMENT '费用',
        grade TINYINT COMMENT '评分'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_get_car_record(uid, city, event_time, end_time, order_id) VALUES
     (101, '北京', '2021-10-01 07:00:00', '2021-10-01 07:02:00', null),
     (102, '北京', '2021-10-01 09:00:30', '2021-10-01 09:01:00', 9001),
     (101, '北京', '2021-10-01 08:28:10', '2021-10-01 08:30:00', 9002),
     (103, '北京', '2021-10-02 07:59:00', '2021-10-02 08:01:00', 9003),
     (104, '北京', '2021-10-03 07:59:20', '2021-10-03 08:01:00', 9004),
     (105, '北京', '2021-10-01 08:00:00', '2021-10-01 08:02:10', 9005),
     (106, '北京', '2021-10-01 17:58:00', '2021-10-01 18:01:00', 9006),
     (107, '北京', '2021-10-02 11:00:00', '2021-10-02 11:01:00', 9007),
     (108, '北京', '2021-10-02 21:00:00', '2021-10-02 21:01:00', 9008) ;
    
    INSERT INTO tb_get_car_order(order_id, uid, driver_id, order_time, start_time, finish_time, mileage, fare, grade) VALUES
     (9002, 101, 201, '2021-10-01 08:30:00', null, '2021-10-01 08:31:00', null, null, null),
     (9001, 102, 202, '2021-10-01 09:01:00', '2021-10-01 09:06:00', '2021-10-01 09:31:00', 10.0, 41.5, 5),
     (9003, 103, 202, '2021-10-02 08:01:00', '2021-10-02 08:15:00', '2021-10-02 08:31:00', 11.0, 41.5, 4),
     (9004, 104, 202, '2021-10-03 08:01:00', '2021-10-03 08:13:00', '2021-10-03 08:31:00', 7.5, 22, 4),
     (9005, 105, 203, '2021-10-01 08:02:10', '2021-10-01 08:18:00', '2021-10-01 08:31:00', 15.0, 44, 5),
     (9006, 106, 203, '2021-10-01 18:01:00', '2021-10-01 18:09:00', '2021-10-01 18:31:00', 8.0, 25, 5),
     (9007, 107, 203, '2021-10-02 11:01:00', '2021-10-02 11:07:00', '2021-10-02 11:31:00', 9.9, 30, 5),
     (9008, 108, 203, '2021-10-02 21:01:00', '2021-10-02 21:10:00', '2021-10-02 21:31:00', 13.2, 38, 4);
    */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45

    用户打车记录表:tb_get_car_record(uid-用户ID,city-城市,event_time-打车时间,end_time-打车结束时间, order_id-订单号),表中数据如下:

    mysql> select * from tb_get_car_record;
    +----+-----+--------+---------------------+---------------------+----------+
    | id | uid | city   | event_time          | end_time            | order_id |
    +----+-----+--------+---------------------+---------------------+----------+
    |  1 | 101 | 北京   | 2021-10-01 07:00:00 | 2021-10-01 07:02:00 |     NULL |
    |  2 | 102 | 北京   | 2021-10-01 09:00:30 | 2021-10-01 09:01:00 |     9001 |
    |  3 | 101 | 北京   | 2021-10-01 08:28:10 | 2021-10-01 08:30:00 |     9002 |
    |  4 | 103 | 北京   | 2021-10-02 07:59:00 | 2021-10-02 08:01:00 |     9003 |
    |  5 | 104 | 北京   | 2021-10-03 07:59:20 | 2021-10-03 08:01:00 |     9004 |
    |  6 | 105 | 北京   | 2021-10-01 08:00:00 | 2021-10-01 08:02:10 |     9005 |
    |  7 | 106 | 北京   | 2021-10-01 17:58:00 | 2021-10-01 18:01:00 |     9006 |
    |  8 | 107 | 北京   | 2021-10-02 11:00:00 | 2021-10-02 11:01:00 |     9007 |
    |  9 | 108 | 北京   | 2021-10-02 21:00:00 | 2021-10-02 21:01:00 |     9008 |
    +----+-----+--------+---------------------+---------------------+----------+
    9 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    打车订单表:tb_get_car_order(order_id-订单号,uid-用户ID,driver_id-司机ID,order_time-接单时间,start_time-开始计费的上车时间,finish_time-订单完成时间,mileage-行驶里程数,fare-费用,grade-评分),表中数据如下:

    mysql> select * from tb_get_car_order;
    +----+----------+-----+-----------+----------------+---------------------+---------+------+-------+
    | id | order_id | uid | driver_id | order_time | start_time| finish_time | mileage | fare | grade |
    +----+----------+-----+-----------+---------------------+---------------+---------+------+-------+
    |1|9002|101|201|2021-10-01 08:30:00 | NULL                | 2021-10-01 08:31:00 |NULL| NULL |NULL |
    |2|9001|102|202|2021-10-01 09:01:00 | 2021-10-01 09:06:00 | 2021-10-01 09:31:00 |10  | 41.5 | 5 |
    |3|9003|103|202|2021-10-02 08:01:00 | 2021-10-02 08:15:00 | 2021-10-02 08:31:00 |11  | 41.5 | 4 |
    |4|9004|104|202|2021-10-03 08:01:00 | 2021-10-03 08:13:00 | 2021-10-03 08:31:00 |7.5 |   22 | 4 |
    |5|9005|105|203|2021-10-01 08:02:10 | 2021-10-01 08:18:00 | 2021-10-01 08:31:00 |15  |   44 | 5 |
    |6|9006|106|203|2021-10-01 18:01:00 | 2021-10-01 18:09:00 | 2021-10-01 18:31:00 |8   |   25 | 5 |
    |7|9007|107|203|2021-10-02 11:01:00 | 2021-10-02 11:07:00 | 2021-10-02 11:31:00 |9.9 |   30 | 5 |
    |8|9008|108|203|2021-10-02 21:01:00 | 2021-10-02 21:10:00 | 2021-10-02 21:31:00 |13.2|   38 | 4 |
    +----+-------------------+---------------------+---------------------+---------+------+-------+
    8 rows in set (0.04 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    说明:

    (1)用户提交打车请求后,在用户打车记录表生成一条打车记录,order_id-订单号设为 null;

    (2)当有司机接单时,在打车订单表生成一条订单,填充 order_time-接单时间及其左边的字段,start_time-开始计费的上车时间及其右边的字段全部为 null,并把 order_id-订单号和 order_time-接单时间**(**end_time-打车结束时间)写入打车记录表;若一直无司机接单,超时或中途用户主动取消打车,则记录 end_time-打车结束时间。

    (3)若乘客上车前,乘客或司机点击取消订单,会将打车订单表对应订单的 finish_time-订单完成时间填充为取消时间,其余字段设为 null。

    (4)当司机接上乘客时,填充订单表中该 start_time-开始计费的上车时间。

    (5)当订单完成时填充订单完成时间、里程数、费用;评分设为 null,在用户给司机打 1~5 星评价后填充。

    【问题】:请统计 2021 年国庆 7 天期间在北京市接单至少 3 次的司机的平均接单数和平均兼职收入(暂不考虑平台佣金,直接计算完成的订单费用总额),结果保留 3 位小数。查询结果如下:

    cityavg_order_numavg_income
    北京3.500121.000

    解答:

    /*
    select '北京' city, 
            round(avg(cnt), 3) avg_order_num, 
            round(avg(sum_fare), 3) avg_income
    from
    (select count(*) cnt, sum(fare) sum_fare
    from tb_get_car_order
    where order_time between '2021-10-01 00:00:00' and '2021-10-07 23:59:59'
          and order_id in
          (select order_id from tb_get_car_record where city= '北京')
    group by driver_id
    having count(*) >= 3) a;
    */
    mysql> select '北京' city, avg(cnt) avg_order_num, avg(sum_fare) avg_income
        -> from
        -> (select count(*) cnt, sum(fare) sum_fare
        -> from tb_get_car_order
        -> where order_time between '2021-10-01 00:00:00' and '2021-10-07 23:59:59'
        ->       and order_id in
        ->       (select order_id from tb_get_car_record where city= '北京')
        -> group by driver_id
        -> having count(*) >= 3) a;
    +--------+---------------+------------+
    | city   | avg_order_num | avg_income |
    +--------+---------------+------------+
    | 北京   |        3.5000 |        121 |
    +--------+---------------+------------+
    1 row in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    178、分组统计查询(6)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_get_car_record,tb_get_car_order;
    CREATE TABLE tb_get_car_record (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        uid INT NOT NULL COMMENT '用户ID',
        city VARCHAR(10) NOT NULL COMMENT '城市',
        event_time datetime COMMENT '打车时间',
        end_time datetime COMMENT '打车结束时间',
        order_id INT COMMENT '订单号'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    CREATE TABLE tb_get_car_order (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        uid INT NOT NULL COMMENT '用户ID',
        driver_id INT NOT NULL COMMENT '司机ID',
        order_time datetime COMMENT '接单时间',
        start_time datetime COMMENT '开始计费的上车时间',
        finish_time datetime COMMENT '订单结束时间',
        mileage FLOAT COMMENT '行驶里程数',
        fare FLOAT COMMENT '费用',
        grade TINYINT COMMENT '评分'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_get_car_record(uid, city, event_time, end_time, order_id) VALUES
     (101, '北京', '2021-10-01 07:00:00', '2021-10-01 07:02:00', null),
     (102, '北京', '2021-10-01 09:00:30', '2021-10-01 09:01:00', 9001),
     (101, '北京', '2021-10-01 08:28:10', '2021-10-01 08:30:00', 9002),
     (103, '北京', '2021-10-02 07:59:00', '2021-10-02 08:01:00', 9003),
     (104, '北京', '2021-10-03 07:59:20', '2021-10-03 08:01:00', 9004),
     (105, '北京', '2021-10-01 08:00:00', '2021-10-01 08:02:10', 9005),
     (106, '北京', '2021-10-01 17:58:00', '2021-10-01 18:01:00', 9006),
     (107, '北京', '2021-10-02 11:00:00', '2021-10-02 11:01:00', 9007),
     (108, '北京', '2021-10-02 21:00:00', '2021-10-02 21:01:00', 9008),
     (109, '北京', '2021-10-08 18:00:00', '2021-10-08 18:01:00', 9009);
    
    INSERT INTO tb_get_car_order(order_id, uid, driver_id, order_time, start_time, finish_time, mileage, fare, grade) VALUES
     (9002, 101, 202, '2021-10-01 08:30:00', null, '2021-10-01 08:31:00', null, null, null),
     (9001, 102, 202, '2021-10-01 09:01:00', '2021-10-01 09:06:00', '2021-10-01 09:31:00', 10.0, 41.5, 5),
     (9003, 103, 202, '2021-10-02 08:01:00', '2021-10-02 08:15:00', '2021-10-02 08:31:00', 11.0, 41.5, 4),
     (9004, 104, 202, '2021-10-03 08:01:00', '2021-10-03 08:13:00', '2021-10-03 08:31:00', 7.5, 22, 4),
     (9005, 105, 203, '2021-10-01 08:02:10', null, '2021-10-01 08:31:00', null, null, null),
     (9006, 106, 203, '2021-10-01 18:01:00', '2021-10-01 18:09:00', '2021-10-01 18:31:00', 8.0, 25.5, 5),
     (9007, 107, 203, '2021-10-02 11:01:00', '2021-10-02 11:07:00', '2021-10-02 11:31:00', 9.9, 30, 5),
     (9008, 108, 203, '2021-10-02 21:01:00', '2021-10-02 21:10:00', '2021-10-02 21:31:00', 13.2, 38, 4),
     (9009, 109, 203, '2021-10-08 18:01:00', '2021-10-08 18:11:50', '2021-10-08 18:51:00', 13, 40, 5);
     */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47

    用户打车记录表:tb_get_car_record(uid-用户ID,city-城市,event_time-打车时间,end_time-打车结束时间, order_id-订单号),表中数据如下:

    mysql> select * from tb_get_car_record;
    +----+-----+--------+---------------------+---------------------+----------+
    | id | uid | city   | event_time          | end_time            | order_id |
    +----+-----+--------+---------------------+---------------------+----------+
    |  1 | 101 | 北京   | 2021-10-01 07:00:00 | 2021-10-01 07:02:00 |     NULL |
    |  2 | 102 | 北京   | 2021-10-01 09:00:30 | 2021-10-01 09:01:00 |     9001 |
    |  3 | 101 | 北京   | 2021-10-01 08:28:10 | 2021-10-01 08:30:00 |     9002 |
    |  4 | 103 | 北京   | 2021-10-02 07:59:00 | 2021-10-02 08:01:00 |     9003 |
    |  5 | 104 | 北京   | 2021-10-03 07:59:20 | 2021-10-03 08:01:00 |     9004 |
    |  6 | 105 | 北京   | 2021-10-01 08:00:00 | 2021-10-01 08:02:10 |     9005 |
    |  7 | 106 | 北京   | 2021-10-01 17:58:00 | 2021-10-01 18:01:00 |     9006 |
    |  8 | 107 | 北京   | 2021-10-02 11:00:00 | 2021-10-02 11:01:00 |     9007 |
    |  9 | 108 | 北京   | 2021-10-02 21:00:00 | 2021-10-02 21:01:00 |     9008 |
    | 10 | 109 | 北京   | 2021-10-08 18:00:00 | 2021-10-08 18:01:00 |     9009 |
    +----+-----+--------+---------------------+---------------------+----------+
    10 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    打车订单表:tb_get_car_order(order_id-订单号,uid-用户ID,driver_id-司机ID,order_time-接单时间,start_time-开始计费的上车时间,finish_time-订单完成时间,mileage-行驶里程数,fare-费用,grade-评分),表中数据如下:

    mysql> select * from tb_get_car_order;
    +----+----------+-----+-----------+--------------+---------------------+---------+------+-------+
    | id | order_id | uid | driver_id | order_time| start_time| finish_time| mileage | fare | grade |
    +----+----------+-----+-----------+--------------+---------------------+---------+------+-------+
    |1|9002|101|202|2021-10-01 08:30:00|NULL               |2021-10-01 08:31:00|NULL |NULL |  NULL |
    |2|9001|102|202|2021-10-01 09:01:00|2021-10-01 09:06:00|2021-10-01 09:31:00|  10 |41.5 |     5 |
    |3|9003|103|202|2021-10-02 08:01:00|2021-10-02 08:15:00|2021-10-02 08:31:00|  11 |41.5 |     4 |
    |4|9004|104|202|2021-10-03 08:01:00|2021-10-03 08:13:00|2021-10-03 08:31:00| 7.5 |  22 |     4 |
    |5|9005|105|203|2021-10-01 08:02:10|NULL               |2021-10-01 08:31:00|NULL |NULL |  NULL |
    |6|9006|106|203|2021-10-01 18:01:00|2021-10-01 18:09:00|2021-10-01 18:31:00|   8 |25.5 |     5 |
    |7|9007|107|203|2021-10-02 11:01:00|2021-10-02 11:07:00|2021-10-02 11:31:00| 9.9 |  30 |     5 |
    |8|9008|108|203|2021-10-02 21:01:00|2021-10-02 21:10:00|2021-10-02 21:31:00|13.2 |  38 |     4 |
    |9|9009|109|203|2021-10-08 18:01:00|2021-10-08 18:11:50|2021-10-08 18:51:00|  13 |  40 |     5 |
    +----+----------+-----+-----------+----------------+---------------------+---------+------+-------+
    9 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    【问题】请查询 2021 年 10 月有过取消订单记录的司机,计算他们每人全部已完成的有评分订单的平均评分及总体平均评分,保留 1 位小数。先按 driver_id 升序输出,再输出总体情况。查询结果如下:

    driver_idavg_grade
    2024.3
    2034.8
    总体4.6

    解答:

    /*
    select driver_id, round(avg(grade), 1) avg_grade
    from tb_get_car_order
    where driver_id in
        (select driver_id
         from tb_get_car_order
         where finish_time between '2021-10-01 00:00:00' and '2021-10-31 23:59:59' and 
               start_time is null)
    group by driver_id
    union
    select '总体' driver_id, round(avg(grade), 1) avg_grade
    from tb_get_car_order
    where driver_id in
        (select driver_id
         from tb_get_car_order
         where finish_time between '2021-10-01 00:00:00' and '2021-10-31 23:59:59' and 
               start_time is null)
    order by driver_id; 
    */
    mysql> select driver_id, round(avg(grade), 1) avg_grade
        -> from tb_get_car_order
        -> where driver_id in
        ->     (select driver_id
        ->      from tb_get_car_order
        ->      where finish_time between '2021-10-01 00:00:00' and '2021-10-31 23:59:59' and 
        ->            start_time is null)
        -> group by driver_id
        -> union
        -> select '总体' driver_id, round(avg(grade), 1) avg_grade
        -> from tb_get_car_order
        -> where driver_id in
        ->     (select driver_id
        ->      from tb_get_car_order
        ->      where finish_time between '2021-10-01 00:00:00' and '2021-10-31 23:59:59' and 
        ->            start_time is null)
        -> order by driver_id; 
    +-----------+-----------+
    | driver_id | avg_grade |
    +-----------+-----------+
    | 202       |       4.3 |
    | 203       |       4.8 |
    | 总体      |       4.6 |
    +-----------+-----------+
    3 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44

    179、分组统计查询(7)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_get_car_record,tb_get_car_order;
    CREATE TABLE tb_get_car_record (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        uid INT NOT NULL COMMENT '用户ID',
        city VARCHAR(10) NOT NULL COMMENT '城市',
        event_time datetime COMMENT '打车时间',
        end_time datetime COMMENT '打车结束时间',
        order_id INT COMMENT '订单号'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    CREATE TABLE tb_get_car_order (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        uid INT NOT NULL COMMENT '用户ID',
        driver_id INT NOT NULL COMMENT '司机ID',
        order_time datetime COMMENT '接单时间',
        start_time datetime COMMENT '开始计费的上车时间',
        finish_time datetime COMMENT '订单结束时间',
        mileage FLOAT COMMENT '行驶里程数',
        fare FLOAT COMMENT '费用',
        grade TINYINT COMMENT '评分'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_get_car_record(uid, city, event_time, end_time, order_id) VALUES
     (101, '北京', '2021-10-01 07:00:00', '2021-10-01 07:02:00', null),
     (102, '北京', '2021-10-01 09:00:30', '2021-10-01 09:01:00', 9001),
     (101, '北京', '2021-10-01 08:28:10', '2021-10-01 08:30:00', 9002),
     (103, '北京', '2021-10-02 07:59:00', '2021-10-02 08:01:00', 9003),
     (104, '北京', '2021-10-03 07:59:20', '2021-10-03 08:01:00', 9004),
     (105, '北京', '2021-10-01 08:00:00', '2021-10-01 08:02:10', 9005),
     (106, '北京', '2021-10-01 17:58:00', '2021-10-01 18:01:00', 9006),
     (107, '北京', '2021-10-02 11:00:00', '2021-10-02 11:01:00', 9007),
     (108, '北京', '2021-10-02 21:00:00', '2021-10-02 21:01:00', 9008),
     (109, '北京', '2021-10-08 18:00:00', '2021-10-08 18:01:00', 9009);
    
    INSERT INTO tb_get_car_order(order_id, uid, driver_id, order_time, start_time, finish_time, mileage, fare, grade) VALUES
     (9002, 101, 202, '2021-10-01 08:30:00', null, '2021-10-01 08:31:00', null, null, null),
     (9001, 102, 202, '2021-10-01 09:01:00', '2021-10-01 09:06:00', '2021-10-01 09:31:00', 10.0, 41.5, 5),
     (9003, 103, 202, '2021-10-02 08:01:00', '2021-10-02 08:15:00', '2021-10-02 08:31:00', 11.0, 41.5, 4),
     (9004, 104, 202, '2021-10-03 08:01:00', '2021-10-03 08:13:00', '2021-10-03 08:31:00', 7.5, 22, 4),
     (9005, 105, 203, '2021-10-01 08:02:10', null, '2021-10-01 08:31:00', null, null, null),
     (9006, 106, 203, '2021-10-01 18:01:00', '2021-10-01 18:09:00', '2021-10-01 18:31:00', 8.0, 25.5, 5),
     (9007, 107, 203, '2021-10-02 11:01:00', '2021-10-02 11:07:00', '2021-10-02 11:31:00', 9.9, 30, 5),
     (9008, 108, 203, '2021-10-02 21:01:00', '2021-10-02 21:10:00', '2021-10-02 21:31:00', 13.2, 38, 4),
     (9009, 109, 203, '2021-10-08 18:01:00', '2021-10-08 18:11:50', '2021-10-08 18:51:00', 13, 40, 5);
     */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47

    用户打车记录表:tb_get_car_record(uid-用户ID,city-城市,event_time-打车时间,end_time-打车结束时间, order_id-订单号),表中数据如下:

    mysql> select * from tb_get_car_record;
    +----+-----+--------+---------------------+---------------------+----------+
    | id | uid | city   | event_time          | end_time            | order_id |
    +----+-----+--------+---------------------+---------------------+----------+
    |  1 | 101 | 北京   | 2021-10-01 07:00:00 | 2021-10-01 07:02:00 |     NULL |
    |  2 | 102 | 北京   | 2021-10-01 09:00:30 | 2021-10-01 09:01:00 |     9001 |
    |  3 | 101 | 北京   | 2021-10-01 08:28:10 | 2021-10-01 08:30:00 |     9002 |
    |  4 | 103 | 北京   | 2021-10-02 07:59:00 | 2021-10-02 08:01:00 |     9003 |
    |  5 | 104 | 北京   | 2021-10-03 07:59:20 | 2021-10-03 08:01:00 |     9004 |
    |  6 | 105 | 北京   | 2021-10-01 08:00:00 | 2021-10-01 08:02:10 |     9005 |
    |  7 | 106 | 北京   | 2021-10-01 17:58:00 | 2021-10-01 18:01:00 |     9006 |
    |  8 | 107 | 北京   | 2021-10-02 11:00:00 | 2021-10-02 11:01:00 |     9007 |
    |  9 | 108 | 北京   | 2021-10-02 21:00:00 | 2021-10-02 21:01:00 |     9008 |
    | 10 | 109 | 北京   | 2021-10-08 18:00:00 | 2021-10-08 18:01:00 |     9009 |
    +----+-----+--------+---------------------+---------------------+----------+
    10 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    打车订单表:tb_get_car_order(order_id-订单号,uid-用户ID,driver_id-司机ID,order_time-接单时间,start_time-开始计费的上车时间,finish_time-订单完成时间,mileage-行驶里程数,fare-费用,grade-评分),表中数据如下:

    mysql> select * from tb_get_car_order;
    +----+----------+-----+-------------------------+---------------------+---------+------+-------+
    | id | order_id | uid | driver_id | order_time| start_time| finish_time| mileage | fare | grade |
    +----+----------+-----+-------------------------+---------------------+---------+------+-------+
    |1|9002|101|202|2021-10-01 08:30:00|NULL               |2021-10-01 08:31:00 |NULL | NULL |NULL |
    |2|9001|102|202|2021-10-01 09:01:00|2021-10-01 09:06:00|2021-10-01 09:31:00 |  10 | 41.5 |   5 |
    |3|9003|103|202|2021-10-02 08:01:00|2021-10-02 08:15:00|2021-10-02 08:31:00 |  11 | 41.5 |   4 |
    |4|9004|104|202|2021-10-03 08:01:00|2021-10-03 08:13:00|2021-10-03 08:31:00 | 7.5 |   22 |   4 |
    |5|9005|105|203|2021-10-01 08:02:10|NULL               |2021-10-01 08:31:00 |NULL | NULL |NULL |
    |6|9006|106|203|2021-10-01 18:01:00|2021-10-01 18:09:00|2021-10-01 18:31:00 |   8 | 25.5 |   5 |
    |7|9007|107|203|2021-10-02 11:01:00|2021-10-02 11:07:00|2021-10-02 11:31:00 | 9.9 |   30 |   5 |
    |8|9008|108|203|2021-10-02 21:01:00|2021-10-02 21:10:00|2021-10-02 21:31:00 |13.2 |   38 |   4 |
    |9|9009|109|203|2021-10-08 18:01:00|2021-10-08 18:11:50|2021-10-08 18:51:00 |  13 |   40 |   5 |
    +----+----------+-----+----------------------+---------------------+---------+------+-------+
    9 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    【问题】请统计每个城市中评分最高的司机平均评分、日均接单量和日均行驶里程数。平均评分和日均接单量保留1位小数,日均行驶里程数保留3位小数,按日均接单数升序排序。查询结果如下:

    说明:如果有多个司机评分并列最高时,都输出。

    citydriver_idavg_gradeavg_order_numavg_mileage
    北京2034.81.714.700

    解答:

    /*
    select gcr.city, gco.driver_id,
           round(avg(grade), 1) avg_grade,
           round(count(*)/count(distinct date(order_time)), 1) avg_order_num,
           round(sum(mileage)/count(distinct date(order_time)), 3) avg_mileage
    from tb_get_car_record gcr join tb_get_car_order gco
    on gcr.order_id = gco.order_id
    group by gcr.city, gco.driver_id
    having avg_grade >= (select round(avg(grade), 1) avg_grade 
                        from tb_get_car_record gcr join tb_get_car_order gco
                         on gcr.order_id = gco.order_id
                         group by gcr.city, gco.driver_id
                        order by avg_grade desc limit 1) 
    order by avg_order_num;
    */
    mysql> select gcr.city, gco.driver_id,
        ->        round(avg(grade), 1) avg_grade,
        ->        round(count(*)/count(distinct date(order_time)), 1) avg_order_num,
        ->        round(sum(mileage)/count(distinct date(order_time)), 3) avg_mileage
        -> from tb_get_car_record gcr join tb_get_car_order gco
        -> on gcr.order_id = gco.order_id
        -> group by gcr.city, gco.driver_id
        -> having avg_grade >= (select round(avg(grade), 1) avg_grade 
        ->                     from tb_get_car_record gcr join tb_get_car_order gco
        ->                      on gcr.order_id = gco.order_id
        ->                      group by gcr.city, gco.driver_id
        ->                     order by avg_grade desc limit 1) 
        -> order by avg_order_num;
    +--------+-----------+-----------+---------------+-------------+
    | city   | driver_id | avg_grade | avg_order_num | avg_mileage |
    +--------+-----------+-----------+---------------+-------------+
    | 北京   |       203 |       4.8 |           1.7 |      14.700 |
    +--------+-----------+-----------+---------------+-------------+
    1 row in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34

    180、分组统计查询(8)

    该题目使用的表和数据如下:

    /*
    DROP TABLE IF EXISTS tb_get_car_record,tb_get_car_order;
    CREATE TABLE tb_get_car_record (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        uid INT NOT NULL COMMENT '用户ID',
        city VARCHAR(10) NOT NULL COMMENT '城市',
        event_time datetime COMMENT '打车时间',
        end_time datetime COMMENT '打车结束时间',
        order_id INT COMMENT '订单号'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    CREATE TABLE tb_get_car_order (
        id INT PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        order_id INT NOT NULL COMMENT '订单号',
        uid INT NOT NULL COMMENT '用户ID',
        driver_id INT NOT NULL COMMENT '司机ID',
        order_time datetime COMMENT '接单时间',
        start_time datetime COMMENT '开始计费的上车时间',
        finish_time datetime COMMENT '订单结束时间',
        mileage FLOAT COMMENT '行驶里程数',
        fare FLOAT COMMENT '费用',
        grade TINYINT COMMENT '评分'
    ) CHARACTER SET utf8 COLLATE utf8_bin;
    
    INSERT INTO tb_get_car_record(uid, city, event_time, end_time, order_id) VALUES
     (101, '北京', '2021-09-25 08:28:10', '2021-09-25 08:30:00', 9011),
     (102, '北京', '2021-09-25 09:00:30', '2021-09-25 09:01:00', 9012),
     (103, '北京', '2021-09-26 07:59:00', '2021-09-26 08:01:00', 9013),
     (104, '北京', '2021-09-26 07:59:00', '2021-09-26 08:01:00', 9023),
     (104, '北京', '2021-09-27 07:59:20', '2021-09-27 08:01:00', 9014),
     (105, '北京', '2021-09-28 08:00:00', '2021-09-28 08:02:10', 9015),
     (106, '北京', '2021-09-29 17:58:00', '2021-09-29 18:01:00', 9016),
     (107, '北京', '2021-09-30 11:00:00', '2021-09-30 11:01:00', 9017),
     (108, '北京', '2021-09-30 21:00:00', '2021-09-30 21:01:00', 9018),
     (102, '北京', '2021-10-01 09:00:30', '2021-10-01 09:01:00', 9002),
     (106, '北京', '2021-10-01 17:58:00', '2021-10-01 18:01:00', 9006),
     (101, '北京', '2021-10-02 08:28:10', '2021-10-02 08:30:00', 9001),
     (107, '北京', '2021-10-02 11:00:00', '2021-10-02 11:01:00', 9007),
     (108, '北京', '2021-10-02 21:00:00', '2021-10-02 21:01:00', 9008),
     (103, '北京', '2021-10-02 07:59:00', '2021-10-02 08:01:00', 9003),
     (104, '北京', '2021-10-03 07:59:20', '2021-10-03 08:01:00', 9004),
     (109, '北京', '2021-10-03 18:00:00', '2021-10-03 18:01:00', 9009);
    
    INSERT INTO tb_get_car_order(order_id, uid, driver_id, order_time, start_time, finish_time, mileage, fare, grade) VALUES
     (9011, 101, 211, '2021-09-25 08:30:00', '2021-09-25 08:31:00', '2021-09-25 08:54:00', 10, 35, 5),
     (9012, 102, 211, '2021-09-25 09:01:00', '2021-09-25 09:01:50', '2021-09-25 09:28:00', 11, 32, 5),
     (9013, 103, 212, '2021-09-26 08:01:00', '2021-09-26 08:03:00', '2021-09-26 08:27:00', 12, 31, 4),
     (9023, 104, 213, '2021-09-26 08:01:00', null, '2021-09-26 08:27:00', null, null, null),
     (9014, 104, 212, '2021-09-27 08:01:00', '2021-09-27 08:04:00', '2021-09-27 08:21:00', 11, 31, 5),
     (9015, 105, 212, '2021-09-28 08:02:10', '2021-09-28 08:04:10', '2021-09-28 08:25:10', 12, 31, 4),
     (9016, 106, 213, '2021-09-29 18:01:00', '2021-09-29 18:02:10', '2021-09-29 18:23:00', 11, 39, 4),
     (9017, 107, 213, '2021-09-30 11:01:00', '2021-09-30 11:01:40', '2021-09-30 11:31:00', 11, 38, 5),
     (9018, 108, 214, '2021-09-30 21:01:00', '2021-09-30 21:02:50', '2021-09-30 21:21:00', 14, 38, 5),
     (9002, 102, 202, '2021-10-01 09:01:00', '2021-10-01 09:06:00', '2021-10-01 09:31:00', 10.0, 41.5, 5),
     (9006, 106, 203, '2021-10-01 18:01:00', '2021-10-01 18:09:00', '2021-10-01 18:31:00', 8.0, 25.5, 4),
     (9001, 101, 202, '2021-10-02 08:30:00', null, '2021-10-02 08:31:00', null, null, null),
     (9007, 107, 203, '2021-10-02 11:01:00', '2021-10-02 11:07:00', '2021-10-02 11:31:00', 9.9, 30, 5),
     (9008, 108, 204, '2021-10-02 21:01:00', '2021-10-02 21:10:00', '2021-10-02 21:31:00', 13.2, 38, 4),
     (9003, 103, 202, '2021-10-02 08:01:00', '2021-10-02 08:15:00', '2021-10-02 08:31:00', 11.0, 41.5, 4),
     (9004, 104, 202, '2021-10-03 08:01:00', '2021-10-03 08:13:00', '2021-10-03 08:31:00', 7.5, 22, 4),
     (9009, 109, 204, '2021-10-03 18:01:00', null, '2021-10-03 18:51:00', null, null, null);
    */
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62

    用户打车记录表:tb_get_car_record(uid-用户ID,city-城市,event_time-打车时间,end_time-打车结束时间, order_id-订单号),表中数据如下:

    mysql> select * from tb_get_car_record;
    +----+-----+--------+---------------------+---------------------+----------+
    | id | uid | city   | event_time          | end_time            | order_id |
    +----+-----+--------+---------------------+---------------------+----------+
    |  1 | 101 | 北京   | 2021-09-25 08:28:10 | 2021-09-25 08:30:00 |     9011 |
    |  2 | 102 | 北京   | 2021-09-25 09:00:30 | 2021-09-25 09:01:00 |     9012 |
    |  3 | 103 | 北京   | 2021-09-26 07:59:00 | 2021-09-26 08:01:00 |     9013 |
    |  4 | 104 | 北京   | 2021-09-26 07:59:00 | 2021-09-26 08:01:00 |     9023 |
    |  5 | 104 | 北京   | 2021-09-27 07:59:20 | 2021-09-27 08:01:00 |     9014 |
    |  6 | 105 | 北京   | 2021-09-28 08:00:00 | 2021-09-28 08:02:10 |     9015 |
    |  7 | 106 | 北京   | 2021-09-29 17:58:00 | 2021-09-29 18:01:00 |     9016 |
    |  8 | 107 | 北京   | 2021-09-30 11:00:00 | 2021-09-30 11:01:00 |     9017 |
    |  9 | 108 | 北京   | 2021-09-30 21:00:00 | 2021-09-30 21:01:00 |     9018 |
    | 10 | 102 | 北京   | 2021-10-01 09:00:30 | 2021-10-01 09:01:00 |     9002 |
    | 11 | 106 | 北京   | 2021-10-01 17:58:00 | 2021-10-01 18:01:00 |     9006 |
    | 12 | 101 | 北京   | 2021-10-02 08:28:10 | 2021-10-02 08:30:00 |     9001 |
    | 13 | 107 | 北京   | 2021-10-02 11:00:00 | 2021-10-02 11:01:00 |     9007 |
    | 14 | 108 | 北京   | 2021-10-02 21:00:00 | 2021-10-02 21:01:00 |     9008 |
    | 15 | 103 | 北京   | 2021-10-02 07:59:00 | 2021-10-02 08:01:00 |     9003 |
    | 16 | 104 | 北京   | 2021-10-03 07:59:20 | 2021-10-03 08:01:00 |     9004 |
    | 17 | 109 | 北京   | 2021-10-03 18:00:00 | 2021-10-03 18:01:00 |     9009 |
    +----+-----+--------+---------------------+---------------------+----------+
    17 rows in set (0.02 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    打车订单表:tb_get_car_order(order_id-订单号,uid-用户ID,driver_id-司机ID,order_time-接单时间,start_time-开始计费的上车时间,finish_time-订单完成时间,mileage-行驶里程数,fare-费用,grade-评分),表中数据如下:

    mysql> select * from tb_get_car_order;
    +----+----------+-----+-----------+---------------+---------------------+---------+------+-------+
    | id | order_id | uid | driver_id | order_time| start_time| finish_time| mileage | fare | grade |
    +----+----------+-----+-----------+---------------------+-------------------------+------+-------+
    | 1|9011|101|211|2021-09-25 08:30:00|2021-09-25 08:31:00|2021-09-25 08:54:00|  10 |   35 |   5 |
    | 2|9012|102|211|2021-09-25 09:01:00|2021-09-25 09:01:50|2021-09-25 09:28:00|  11 |   32 |   5 |
    | 3|9013|103|212|2021-09-26 08:01:00|2021-09-26 08:03:00|2021-09-26 08:27:00|  12 |   31 |   4 |
    | 4|9023|104|213|2021-09-26 08:01:00|NULL               |2021-09-26 08:27:00|NULL | NULL |NULL |
    | 5|9014|104|212|2021-09-27 08:01:00|2021-09-27 08:04:00|2021-09-27 08:21:00|  11 |   31 |   5 |
    | 6|9015|105|212|2021-09-28 08:02:10|2021-09-28 08:04:10|2021-09-28 08:25:10|  12 |   31 |   4 |
    | 7|9016|106|213|2021-09-29 18:01:00|2021-09-29 18:02:10|2021-09-29 18:23:00|  11 |   39 |   4 |
    | 8|9017|107|213|2021-09-30 11:01:00|2021-09-30 11:01:40|2021-09-30 11:31:00|  11 |   38 |   5 |
    | 9|9018|108|214|2021-09-30 21:01:00|2021-09-30 21:02:50|2021-09-30 21:21:00|  14 |   38 |   5 |
    |10|9002|102|202|2021-10-01 09:01:00|2021-10-01 09:06:00|2021-10-01 09:31:00|  10 | 41.5 |   5 |
    |11|9006|106|203|2021-10-01 18:01:00|2021-10-01 18:09:00|2021-10-01 18:31:00|   8 | 25.5 |   4 |
    |12|9001|101|202|2021-10-02 08:30:00|NULL               |2021-10-02 08:31:00|NULL | NULL |NULL |
    |13|9007|107|203|2021-10-02 11:01:00|2021-10-02 11:07:00|2021-10-02 11:31:00| 9.9 |   30 |   5 |
    |14|9008|108|204|2021-10-02 21:01:00|2021-10-02 21:10:00|2021-10-02 21:31:00|13.2 |   38 |   4 |
    |15|9003|103|202|2021-10-02 08:01:00|2021-10-02 08:15:00|2021-10-02 08:31:00|  11 | 41.5 |   4 |
    |16|9004|104|202|2021-10-03 08:01:00|2021-10-03 08:13:00|2021-10-03 08:31:00| 7.5 |   22 |   4 |
    |17|9009|109|204|2021-10-03 18:01:00|NULL               |2021-10-03 18:51:00|NULL | NULL |NULL |
    +-----+---------------------+---------------------+---------------------+---------+------+-------+
    17 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    【问题】请统计国庆头 3 天,每天的近 7 日日均订单完成量和日均订单取消量,按日期升序排序。结果保留 2 位小数。查询结果如下:

    dtfinish_num_7dcancel_num_7d
    2021-10-011.430.14
    2021-10-021.570.29
    2021-10-031.570.29

    解答:

    /*
    select date(order_time) dt, 
           round((select count(*) from tb_get_car_order 
                  where date(order_time) between adddate(dt, -6) and dt
                        and start_time is not null)/7, 2) finish_num_7d,
           round((select count(*) from tb_get_car_order 
                  where date(order_time) between adddate(dt, -6) and dt
                         and start_time is null)/7, 2) cancel_num_7d
    from tb_get_car_order
    where order_time between '2021-10-01 00:00:00' and '2021-10-03 23:59:59'
    group by dt
    order by dt;
    */
    mysql> select date(order_time) dt, 
        ->        round((select count(*) from tb_get_car_order 
        ->               where date(order_time) between adddate(dt, -6) and dt
        ->                     and start_time is not null)/7, 2) finish_num_7d,
        ->        round((select count(*) from tb_get_car_order 
        ->               where date(order_time) between adddate(dt, -6) and dt
        ->                      and start_time is null)/7, 2) cancel_num_7d
        -> from tb_get_car_order
        -> where order_time between '2021-10-01 00:00:00' and '2021-10-03 23:59:59'
        -> group by dt
        -> order by dt;
    +------------+---------------+---------------+
    | dt         | finish_num_7d | cancel_num_7d |
    +------------+---------------+---------------+
    | 2021-10-01 |          1.43 |          0.14 |
    | 2021-10-02 |          1.57 |          0.29 |
    | 2021-10-03 |          1.57 |          0.29 |
    +------------+---------------+---------------+
    3 rows in set (0.00 sec)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
  • 相关阅读:
    JavaScript简介&引入方式(JavaScript基础语法、JavaScript对象、BOM、DOM、事件监听)
    Linux简单shell脚本部署项目
    vue3中使用svg并封装成组件
    性能测试常见故障和解决思路
    LeetCode--180 连续出现的数字
    十、【React-Router6】Component 汇总
    【Javascript】定时器
    curl命令使用
    主动获取用户的ColaKey接口
    CSS 之 z-index 属性详解
  • 原文地址:https://blog.csdn.net/weixin_44377973/article/details/126174937