-
leetcode - 1633. Percentage of Users Attended a ContestSQL 문제풀이 2022. 7. 22. 14:55
난이도 : Easy
Table: Users
+-------------+---------+ | Column Name | Type | +-------------+---------+ | user_id | int | | user_name | varchar | +-------------+---------+ user_id is the primary key for this table. Each row of this table contains the name and the id of a user.
Table: Register
+-------------+---------+ | Column Name | Type | +-------------+---------+ | contest_id | int | | user_id | int | +-------------+---------+ (contest_id, user_id) is the primary key for this table. Each row of this table contains the id of a user and the contest they registered into.
Write an SQL query to find the percentage of the users registered in each contest rounded to two decimals.
Return the result table ordered by percentage in descending order. In case of a tie, order it by contest_id in ascending order.
The query result format is in the following example.
Example 1:
Input: Users table: +---------+-----------+ | user_id | user_name | +---------+-----------+ | 6 | Alice | | 2 | Bob | | 7 | Alex | +---------+-----------+ Register table: +------------+---------+ | contest_id | user_id | +------------+---------+ | 215 | 6 | | 209 | 2 | | 208 | 2 | | 210 | 6 | | 208 | 6 | | 209 | 7 | | 209 | 6 | | 215 | 7 | | 208 | 7 | | 210 | 2 | | 207 | 2 | | 210 | 7 | +------------+---------+ Output: +------------+------------+ | contest_id | percentage | +------------+------------+ | 208 | 100.0 | | 209 | 100.0 | | 210 | 100.0 | | 215 | 66.67 | | 207 | 33.33 | +------------+------------+ Explanation: All the users registered in contests 208, 209, and 210. The percentage is 100% and we sort them in the answer table by contest_id in ascending order. Alice and Alex registered in contest 215 and the percentage is ((2/3) * 100) = 66.67% Bob registered in contest 207 and the percentage is ((1/3) * 100) = 33.33%
SELECT contest_id , ROUND(COUNT(Register.user_id)*100 / (SELECT COUNT(Users.user_id) FROM Users), 2) percentage FROM Users LEFT JOIN Register ON Users.user_id = Register.user_Id WHERE contest_id is not null GROUP BY contest_id ORDER BY percentage desc, contest_id
Accepted (18.11%)
'SQL 문제풀이' 카테고리의 다른 글
leetcode - 1667. Fix Names in a Table (0) 2022.07.22 leetcode - 1661. Average Time of Process per Machine (0) 2022.07.22 leetcode - 1158. Market Analysis I (0) 2022.07.20 leetcode - 1149. Article Views II (0) 2022.07.20 leetcode - 1623. All Valid Triplets That Can Represent a Country (0) 2022.07.19