Leetcode597. 好友申请 I :总体通过率(简单)

在 Facebook 或者 Twitter 这样的社交应用中,人们经常会发好友申请也会收到其他人的好友申请。现在给如下两个表:

表: friend_request

| 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 |
 

表: request_accepted

| 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 |
 

写一个查询语句,求出好友申请的通过率,用 2 位小数表示。通过率由接受好友申请的数目除以申请总数。

对于上面的样例数据,你的查询语句应该返回如下结果。

|accept_rate|
|-----------|
|       0.80|

注意:
通过的好友申请不一定都在表 friend_request 中。在这种情况下,你只需要统计总的被通过的申请数(不管它们在不在原来的申请中),并将它除以申请总数,得到通过率
一个好友申请发送者有可能会给接受者发几条好友申请,也有可能一个好友申请会被通过好几次。这种情况下,重复的好友申请只统计一次。
如果一个好友申请都没有,通过率为 0.00 。

审题
好像题目的描述有些绕
friend_request是发起申请的表 ;sender_id 是发出申请的id; send_to_id 是向谁申请的id;
request_accepted是接受申请的表; requester_id是接受的申请中发起申请的id; accepter_id是接受申请的id;
题目中接受申请的有一条重复,一共四条;而总的请求数目为五条。
所以通过率为4/5。

题目中说道,通过的好友申请不一定都在表 friend_request 中。
没懂啥意思。。。

解答
对于request_accepted选出不重复的个数再除以 friend_request中不重复的个数即可
如果为NULL则赋值为0

select ifnull(round(count(distinct R.requester_id, R.accepter_id) / 
count(distinct F.sender_id F.send_to_id), 2), 
0 ) AS `accept_rate`
from request_accepted AS R, friend_request AS F;

你可能感兴趣的:(Leetcode597. 好友申请 I :总体通过率(简单))