-
leetcode - 1174. Immediate Food Delivery IISQL 문제풀이 2022. 7. 22. 16:27
난이도 : Medium
Table: Delivery
+-----------------------------+---------+ | Column Name | Type | +-----------------------------+---------+ | delivery_id | int | | customer_id | int | | order_date | date | | customer_pref_delivery_date | date | +-----------------------------+---------+ delivery_id is the primary key of this table. The table holds information about food delivery to customers that make orders at some date and specify a preferred delivery date (on the same order date or after it).
If the customer's preferred delivery date is the same as the order date, then the order is called immediate; otherwise, it is called scheduled.
The first order of a customer is the order with the earliest order date that the customer made. It is guaranteed that a customer has precisely one first order.
Write an SQL query to find the percentage of immediate orders in the first orders of all customers, rounded to 2 decimal places.
The query result format is in the following example.
Example 1:
Input: Delivery table: +-------------+-------------+------------+-----------------------------+ | delivery_id | customer_id | order_date | customer_pref_delivery_date | +-------------+-------------+------------+-----------------------------+ | 1 | 1 | 2019-08-01 | 2019-08-02 | | 2 | 2 | 2019-08-02 | 2019-08-02 | | 3 | 1 | 2019-08-11 | 2019-08-12 | | 4 | 3 | 2019-08-24 | 2019-08-24 | | 5 | 3 | 2019-08-21 | 2019-08-22 | | 6 | 2 | 2019-08-11 | 2019-08-13 | | 7 | 4 | 2019-08-09 | 2019-08-09 | +-------------+-------------+------------+-----------------------------+ Output: +----------------------+ | immediate_percentage | +----------------------+ | 50.00 | +----------------------+ Explanation: The customer id 1 has a first order with delivery id 1 and it is scheduled. The customer id 2 has a first order with delivery id 2 and it is immediate. The customer id 3 has a first order with delivery id 5 and it is scheduled. The customer id 4 has a first order with delivery id 7 and it is immediate. Hence, half the customers have immediate first orders.
WITH sub AS ( SELECT delivery_id , customer_id , CASE WHEN order_date = customer_pref_delivery_date THEN 'immediate' ELSE 'scheduled' END delivery FROM Delivery WHERE (customer_id, order_date) IN ( SELECT customer_id , MIN(order_date) first_order_date FROM Delivery GROUP BY customer_id ) GROUP BY delivery_id ) SELECT ROUND(SUM(IF(delivery = 'immediate', 1, 0)) * 100 / COUNT(*), 2) immediate_percentage FROM sub
Accepted (44.79%)
'SQL 문제풀이' 카테고리의 다른 글
leetcode - 1683. Invalid Tweets (0) 2022.07.25 leetcode - 1677. Product's Worth Over Invoices (0) 2022.07.25 leetcode - 1164. Product Price at a Given Date (0) 2022.07.22 leetcode - 1667. Fix Names in a Table (0) 2022.07.22 leetcode - 1661. Average Time of Process per Machine (0) 2022.07.22