Leetcode力扣 MySQL数据库 1501 可以放心投资的国家

1501 可以放心投资的国家


SQL架构

Create table If Not Exists Person_1501 (id int, name varchar(15), phone_number varchar(11));
Create table If Not Exists Country_1501 (name varchar(15), country_code varchar(3));
Create table If Not Exists Calls_1501 (caller_id int, callee_id int, duration int);
Truncate table Person_1501;
insert into Person_1501 (id, name, phone_number) values ('3', 'Jonathan', '051-1234567');
insert into Person_1501 (id, name, phone_number) values ('12', 'Elvis', '051-7654321');
insert into Person_1501 (id, name, phone_number) values ('1', 'Moncef', '212-1234567');
insert into Person_1501 (id, name, phone_number) values ('2', 'Maroua', '212-6523651');
insert into Person_1501 (id, name, phone_number) values ('7', 'Meir', '972-1234567');
insert into Person_1501 (id, name, phone_number) values ('9', 'Rachel', '972-0011100');
Truncate table Country_1501;
insert into Country_1501 (name, country_code) values ('Peru', '051');
insert into Country_1501 (name, country_code) values ('Israel', '972');
insert into Country_1501 (name, country_code) values ('Morocco', '212');
insert into Country_1501 (name, country_code) values ('Germany', '049');
insert into Country_1501 (name, country_code) values ('Ethiopia', '251');
Truncate table Calls_1501;
insert into Calls_1501 (caller_id, callee_id, duration) values ('1', '9', '33');
insert into Calls_1501 (caller_id, callee_id, duration) values ('2', '9', '4');
insert into Calls_1501 (caller_id, callee_id, duration) values ('1', '2', '59');
insert into Calls_1501 (caller_id, callee_id, duration) values ('3', '12', '102');
insert into Calls_1501 (caller_id, callee_id, duration) values ('3', '12', '330');
insert into Calls_1501 (caller_id, callee_id, duration) values ('12', '3', '5');
insert into Calls_1501 (caller_id, callee_id, duration) values ('7', '9', '13');
insert into Calls_1501 (caller_id, callee_id, duration) values ('7', '1', '3');
insert into Calls_1501 (caller_id, callee_id, duration) values ('9', '7', '1');
insert into Calls_1501 (caller_id, callee_id, duration) values ('1', '7', '7');


表 Person:

+----------------+---------+
| Column Name    | Type    |
+----------------+---------+
| id             | int     |
| name           | varchar |
| phone_number   | varchar |
+----------------+---------+
id 是该表主键.
该表每一行包含一个人的名字和电话号码.
电话号码的格式是:'xxx-yyyyyyy', 其中xxx是国家码(3个字符), yyyyyyy是电话号码(7个字符), x和y都表示数字. 同时, 国家码和电话号码都可以包含前导0.
表 Country:

+----------------+---------+
| Column Name    | Type    |
+----------------+---------+
| name           | varchar |
| country_code   | varchar |
+----------------+---------+
country_code是该表主键.
该表每一行包含国家名和国家码. country_code的格式是'xxx', x是数字.

表 Calls:

+-------------+------+
| Column Name | Type |
+-------------+------+
| caller_id   | int  |
| callee_id   | int  |
| duration    | int  |
+-------------+------+
该表无主键, 可能包含重复行.
每一行包含呼叫方id, 被呼叫方id和以分钟为单位的通话时长. caller_id != callee_id
一家电信公司想要投资新的国家. 该公司想要投资的国家是:  该国的平均通话时长要严格地大于全球平均通话时长.

写一段 SQL,  找到所有该公司可以投资的国家.

返回的结果表没有顺序要求.

查询的结果格式如下例所示.

Person 表:
+----+----------+--------------+
| id | name     | phone_number |
+----+----------+--------------+
| 3  | Jonathan | 051-1234567  |
| 12 | Elvis    | 051-7654321  |
| 1  | Moncef   | 212-1234567  |
| 2  | Maroua   | 212-6523651  |
| 7  | Meir     | 972-1234567  |
| 9  | Rachel   | 972-0011100  |
+----+----------+--------------+

Country 表:
+----------+--------------+
| name     | country_code |
+----------+--------------+
| Peru     | 051          |
| Israel   | 972          |
| Morocco  | 212          |
| Germany  | 049          |
| Ethiopia | 251          |
+----------+--------------+

Calls 表:
+-----------+-----------+----------+
| caller_id | callee_id | duration |
+-----------+-----------+----------+
| 1         | 9         | 33       |
| 2         | 9         | 4        |
| 1         | 2         | 59       |
| 3         | 12        | 102      |
| 3         | 12        | 330      |
| 12        | 3         | 5        |
| 7         | 9         | 13       |
| 7         | 1         | 3        |
| 9         | 7         | 1        |
| 1         | 7         | 7        |
+-----------+-----------+----------+

Result 表:
+----------+
| country  |
+----------+
| Peru     |
+----------+
国家Peru的平均通话时长是 (102 + 102 + 330 + 330 + 5 + 5) / 6 = 145.666667
国家Israel的平均通话时长是 (33 + 4 + 13 + 13 + 3 + 1 + 1 + 7) / 8 = 9.37500
国家Morocco的平均通话时长是 (33 + 4 + 59 + 59 + 3 + 7) / 6 = 27.5000 
全球平均通话时长 = (2 * (33 + 4 + 59 + 102 + 330 + 5 + 13 + 3 + 1 + 7)) / 20 = 55.70000
所以, Peru是唯一的平均通话时长大于全球平均通话时长的国家, 也是唯一的推荐投资的国家.


解题

SELECT c.name AS country
FROM Calls_1501, Person_1501, Country_1501 c
WHERE (caller_id = id OR callee_id = id) AND country_code = LEFT(phone_number, 3)
GROUP BY country
HAVING AVG(duration) > (SELECT AVG(duration) FROM Calls_1501);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ziko-1101

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值