SQL面试题挑战04:找出使用相同ip的用户

问题:

现在有一张用户登陆日志表,该表包括user_id,ip,log_time三个字段,现在需要找出共同使用ip数量超过3个(含)的所有用户对。比如下面的示例数据,101和102用户共同使用的ip为4个,101和103用户共同使用的ip为3个,102和103用户共同使用的ip为3个。

(101,'192.168.10.101','2022-05-10 11:00:00'),
(101,'192.168.10.101','2022-05-10 11:01:00'),
(101,'192.168.10.102','2022-05-10 11:02:00'),
(101,'192.168.10.103','2022-05-10 11:03:00'),
(101,'192.168.10.104','2022-05-10 11:04:00'),

(102,'192.168.10.101','2022-05-10 11:04:30'),
(102,'192.168.10.102','2022-05-10 11:05:00'),
(102,'192.168.10.103','2022-05-10 11:06:00'),
(102,'192.168.10.104','2022-05-10 11:07:00'),

(103,'192.168.10.102','2022-05-10 11:08:00'),
(103,'192.168.10.103','2022-05-10 11:08:00'),
(103,'192.168.10.104','2022-05-10 11:10:00'),

(104,'192.168.10.103','2022-05-10 11:11:00'),
(104,'192.168.10.104','2022-05-10 11:12:00'),

(105,'192.168.10.105','2022-05-10 11:13:00')

SQL解答:

问题的关键点是使用自连接,先按用户和ip去重之后进行自关联。因为如果公共使用ip达到3个及以上的话,那么同一个用户对至少会出现3条数据,筛选一下就行。

with user_login as (
select 101 as user_id ,'192.168.10.101' as ip ,'2022-05-10 11:00:00' as log_time
union all                                                            
select 101 as user_id ,'192.168.10.101' as ip ,'2022-05-10 11:01:00' as log_time
union all                                                            
select 101 as user_id ,'192.168.10.102' as ip ,'2022-05-10 11:02:00' as log_time
union all                                                            
select 101 as user_id ,'192.168.10.103' as ip ,'2022-05-10 11:03:00' as log_time
union all                                                            
select 101 as user_id ,'192.168.10.104' as ip ,'2022-05-10 11:04:00' as log_time
union all                                                            
select 102 as user_id ,'192.168.10.101' as ip ,'2022-05-10 11:04:30' as log_time
union all                                                            
select 102 as user_id ,'192.168.10.102' as ip ,'2022-05-10 11:05:00' as log_time
union all                                                            
select 102 as user_id ,'192.168.10.103' as ip ,'2022-05-10 11:06:00' as log_time
union all                                                            
select 102 as user_id ,'192.168.10.104' as ip ,'2022-05-10 11:07:00' as log_time
union all                                                            
select 103 as user_id ,'192.168.10.102' as ip ,'2022-05-10 11:08:00' as log_time
union all                                                            
select 103 as user_id ,'192.168.10.103' as ip ,'2022-05-10 11:08:00' as log_time
union all                                                            
select 103 as user_id ,'192.168.10.104' as ip ,'2022-05-10 11:10:00' as log_time
union all                                                            
select 104 as user_id ,'192.168.10.103' as ip ,'2022-05-10 11:11:00' as log_time
union all                                                            
select 104 as user_id ,'192.168.10.104' as ip ,'2022-05-10 11:12:00' as log_time
union all                                                            
select 105 as user_id ,'192.168.10.105' as ip ,'2022-05-10 11:13:00' as log_time
),
tmp as
(
    select 
    user_id
    ,ip
    from user_login --实际换成自己的表或上面的样例数据
    group by user_id,ip  --同一个ip同一用户可能多次登录,先去重
)

select
t1.user_id
,t2.user_id
,count(t1.ip) as ip_cnt
from tmp t1
inner join tmp t2
on t1.ip=t2.ip  --通过ip自关联
where t1.user_id<t2.user_id  --因为存在101对102,102对101的情况,保留一种即可
group by t1.user_id,t2.user_id
having ip_cnt>=3  --保留用户对ip数量超过3个的(含)

相关推荐

  1. SQL面试挑战04使用相同ip用户

    2023-12-22 08:50:02       62 阅读
  2. SQL面试挑战06:互相关注

    2023-12-22 08:50:02       50 阅读
  3. SQL面试挑战03:奖金瓜分问题(拼多多)

    2023-12-22 08:50:02       57 阅读
  4. SQL面试挑战08:补全缺失日月销售累计

    2023-12-22 08:50:02       61 阅读
  5. SQL面试挑战14:每年在校人数

    2023-12-22 08:50:02       59 阅读
  6. SQL面试挑战13:分组topN

    2023-12-22 08:50:02       65 阅读
  7. SQL面试挑战02:同时最大在线人数问题

    2023-12-22 08:50:02       63 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-22 08:50:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-22 08:50:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-22 08:50:02       82 阅读
  4. Python语言-面向对象

    2023-12-22 08:50:02       91 阅读

热门阅读

  1. vue整合axios 未完

    2023-12-22 08:50:02       68 阅读
  2. C++ 如何对二维map进行读和写

    2023-12-22 08:50:02       46 阅读
  3. c++导入外部的依赖开源库

    2023-12-22 08:50:02       52 阅读
  4. 在 Python 中实现单例模式

    2023-12-22 08:50:02       73 阅读
  5. git如何修改提交代码时的名字和邮箱?

    2023-12-22 08:50:02       65 阅读
  6. git stash 用法总结

    2023-12-22 08:50:02       58 阅读
  7. Http 请求体和响应体中重要的字段

    2023-12-22 08:50:02       55 阅读
  8. cka从入门到放弃

    2023-12-22 08:50:02       55 阅读
  9. nodejs设置x-xss-protection解决xss问题

    2023-12-22 08:50:02       60 阅读