zoukankan      html  css  js  c++  java
  • [LeetCode]-DataBase-Trips and Users

    The Trips table holds all taxi trips. Each trip has a unique Id, while Client_Id and Driver_Id are both foreign keys to the Users_Id at the Users table. Status is an ENUM type of (‘completed’, ‘cancelled_by_driver’, ‘cancelled_by_client’).

    +----+-----------+-----------+---------+--------------------+----------+
    | Id | Client_Id | Driver_Id | City_Id |        Status      |Request_at|
    +----+-----------+-----------+---------+--------------------+----------+
    | 1  |     1     |    10     |    1    |     completed      |2013-10-01|
    | 2  |     2     |    11     |    1    | cancelled_by_driver|2013-10-01|
    | 3  |     3     |    12     |    6    |     completed      |2013-10-01|
    | 4  |     4     |    13     |    6    | cancelled_by_client|2013-10-01|
    | 5  |     1     |    10     |    1    |     completed      |2013-10-02|
    | 6  |     2     |    11     |    6    |     completed      |2013-10-02|
    | 7  |     3     |    12     |    6    |     completed      |2013-10-02|
    | 8  |     2     |    12     |    12   |     completed      |2013-10-03|
    | 9  |     3     |    10     |    12   |     completed      |2013-10-03| 
    | 10 |     4     |    13     |    12   | cancelled_by_driver|2013-10-03|
    +----+-----------+-----------+---------+--------------------+----------+
    

    The Users table holds all users. Each user has an unique Users_Id, and Role is an ENUM type of (‘client’, ‘driver’, ‘partner’).

    +----------+--------+--------+
    | Users_Id | Banned |  Role  |
    +----------+--------+--------+
    |    1     |   No   | client |
    |    2     |   Yes  | client |
    |    3     |   No   | client |
    |    4     |   No   | client |
    |    10    |   No   | driver |
    |    11    |   No   | driver |
    |    12    |   No   | driver |
    |    13    |   No   | driver |
    +----------+--------+--------+
    

    Write a SQL query to find the cancellation rate of requests made by unbanned clients between Oct 1, 2013 and Oct 3, 2013. For the above tables, your SQL query should return the following rows with the cancellation rate being rounded to two decimal places.

    +------------+-------------------+
    |     Day    | Cancellation Rate |
    +------------+-------------------+
    | 2013-10-01 |       0.33        |
    | 2013-10-02 |       0.00        |
    | 2013-10-03 |       0.50        |
    +------------+-------------------+
    

    需求:查询由未绑定的客户端发起的已经取消的订单的占比

    create table Trips(
    Id tinyint unsigned auto_increment primary key,
    Client_Id tinyint unsigned ,
    Driver_Id tinyint unsigned ,
    City_Id tinyint unsigned,
    Status enum('completed', 'cancelled_by_driver', 'cancelled_by_client'),
    Request_at date,
    foreign key(Client_Id) references Users(Users_Id),
    foreign key(Driver_Id) references Users(Users_Id)
    )ENGINE=MyISAM;
    create table Users(
    Users_Id tinyint unsigned auto_increment primary key,
    Banned varchar(10),
    Role enum('client', 'driver', 'partner')
    )ENGINE=MyISAM;
    -- 插入数据
    INSERT Trips(Id,Client_Id,Driver_Id,City_Id,Status,Request_at)
    VALUES(1,1,10,1 ,'completed','2013-10-01'),
    ( 2 ,2,11,1 ,'cancelled_by_driver','2013-10-01'),
    (3 ,3,12,6 ,'completed','2013-10-01'),
    ( 4 ,4,13,6 ,'cancelled_by_client','2013-10-01'),
    ( 5 ,1,10,1 ,'completed','2013-10-02'),
    ( 6 ,2,11,6 ,'completed','2013-10-02'),
    ( 7 ,3,12,6 ,'completed','2013-10-02'),
    ( 8 ,2,12,12,'completed','2013-10-03'),
    ( 9 ,3,10,12,'completed','2013-10-03'),
    ( 10,4,13,12,'cancelled_by_driver','2013-10-03')


    -- Write a SQL query to find the cancellation rate of requests made by unbanned clients
    -- between Oct 1, 2013 and Oct 3, 2013.

    -- SQL
    SELECT a.dt AS 'Day',IF(b.cnt/a.total IS NULL,0.00,ROUND(b.cnt/a.total,2)) AS 'Cancellation Rate'
    FROM (
    SELECT t1.Request_at AS dt,COUNT(*) AS total
    FROM Trips t1 LEFT JOIN Users t2 ON t2.Users_Id=t1.Client_Id
    WHERE t2.Role='client' AND t2.Banned='No' AND t1.Request_at BETWEEN '2013-10-01' AND '2013-10-03'
    GROUP BY Request_at
    ) a LEFT JOIN(
    SELECT t1.Request_at AS dt,COUNT(*) AS cnt
    FROM Trips t1
    LEFT JOIN Users t2 ON t2.Users_Id=t1.Client_Id
    WHERE t2.Role='client' AND t2.Banned='No' AND t1.Status LIKE 'cancelled%'
    AND t1.Request_at BETWEEN '2013-10-01' AND '2013-10-03'
    GROUP BY t1.Request_at
    ) b ON a.dt=b.dt

  • 相关阅读:
    python模块--time模块
    python模块--如何相互调用自己写的模块
    Animating Views Using Scenes and Transitions
    fragment 切换
    android textview 设置text 字体
    android intent 5.1
    android EditView ime
    animation of android (4)
    animation of android (3)
    animation of android (2)
  • 原文地址:https://www.cnblogs.com/lianliang/p/5306886.html
Copyright © 2011-2022 走看看