LeetCode:Database 25.好友申请 I:总体通过率
Posted Xiao Miao
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode:Database 25.好友申请 I:总体通过率相关的知识,希望对你有一定的参考价值。
要求:写一个查询语句,求出好友申请的通过率,用 2 位小数表示。通过率由接受好友申请的数目除以申请总数。
FriendRequest表结构:
+----------------+---------+
| Column Name | Type |
+----------------+---------+
| sender_id | int |
| send_to_id | int |
| request_date | date |
+----------------+---------+
此表没有主键,它可能包含重复项。
该表包含发送请求的用户的 ID ,接受请求的用户的 ID 以及请求的日期。
RequestAccepted表结构:
+----------------+---------+
| Column Name | Type |
+----------------+---------+
| requester_id | int |
| accepter_id | int |
| accept_date | date |
+----------------+---------+
此表没有主键,它可能包含重复项。
该表包含发送请求的用户的 ID ,接受请求的用户的 ID 以及请求通过的日期。
FriendRequest表:
+-----------+------------+--------------+
| sender_id | send_to_id | request_date |
+-----------+------------+--------------+
| 1 | 2 | 2016/06/01 |
| 1 | 3 | 2016/06/01 |
| 1 | 4 | 2016/06/01 |
| 2 | 3 | 2016/06/02 |
| 3 | 4 | 2016/06/09 |
+-----------+------------+--------------+
RequestAccepted 表:
+--------------+-------------+-------------+
| requester_id | accepter_id | accept_date |
+--------------+-------------+-------------+
| 1 | 2 | 2016/06/03 |
| 1 | 3 | 2016/06/08 |
| 2 | 3 | 2016/06/08 |
| 3 | 4 | 2016/06/09 |
| 3 | 4 | 2016/06/10 |
+--------------+-------------+-------------+
Result Table:
+-------------+
| accept_rate |
+-------------+
| 0.8 |
+-------------+
总共有 5 个请求,有 4 个不同的通过请求,所以通过率是 0.80
分析:
1.需要求得好友申请通过率,通过率等于通过总人数除以申请总人数,通过distinct去重后求得总人数
2.要求结果不能为null,因此需要将null值变为0.00
SQL语句:
select if(c is null,0.00,c) as accept_rate from(
SELECT round(COUNT(DISTINCT requester_id,accepter_id)/COUNT(DISTINCT a.sender_id,a.send_to_id),2) as c
FROM friendrequest a
JOIN requestaccepted b)d;
以上是关于LeetCode:Database 25.好友申请 I:总体通过率的主要内容,如果未能解决你的问题,请参考以下文章
sAP采购申请23815183的项目00010已被删除怎么办?