列表

详情


597. 好友申请 I:总体通过率

表:FriendRequest

+----------------+---------+
| Column Name    | Type    |
+----------------+---------+
| sender_id      | int     |
| send_to_id     | int     |
| request_date   | date    |
+----------------+---------+
该表可能包含重复项(换句话说,在SQL中,该表没有主键)。
该表包含发送请求的用户的 ID ,接受请求的用户的 ID 以及请求的日期。

 

表:RequestAccepted

+----------------+---------+
| Column Name    | Type    |
+----------------+---------+
| requester_id   | int     |
| accepter_id    | int     |
| accept_date    | date    |
+----------------+---------+
该表可能包含重复项(换句话说,在SQL中,该表没有主键)。
该表包含发送请求的用户的 ID ,接受请求的用户的 ID 以及请求通过的日期。

 

求出好友申请的通过率,用 2 位小数表示。通过率由接受好友申请的数目除以申请总数。

提示:

返回结果应该如下例所示。

 

示例 1:

输入:
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  |
+--------------+-------------+-------------+
输出:
+-------------+
| accept_rate |
+-------------+
| 0.8         |
+-------------+
解释:
总共有 5 个请求,有 4 个不同的通过请求,所以通过率是 0.80

 

进阶:

原站题解

去查看

上次编辑到这里,代码来自缓存 点击恢复默认模板
# Write your MySQL query statement below

mysql 解法, 执行用时: 435 ms, 内存消耗: 0 B, 提交时间: 2023-10-15 16:54:14

select
round(
    ifnull(
    (select count(*) from (select distinct requester_id, accepter_id from RequestAccepted) as A)
    /
    (select count(*) from (select distinct sender_id, send_to_id from FriendRequest) as B),
    0)
, 2) as accept_rate;

上一题