sql面试题之”找出使用相同ip的用户“

现有一张表,里面有三个字段为user_id、ip、log_time,现有需求要找出用户共同使用ip数量大于等于3个的用户对找出来。

1.表数据准备


--建表语句  
  create table dms.user_login_log(
  user_id   string 
  ,ip       string
  ,log_time string
  );
--插入数据  
  insert into dms.user_login_log values
(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'),  
(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'),

(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')

2.需求分析

我们最终想要获取的是公共使用ip数量超过3的用户对,比如:101和102 共用了4个IP,101和103公用了3个IP,102和103公用3个。可以通过自关联实现。

3.实现sql如下

 select  
        A1.user_id
       ,A2.user_id
       ,count(1)
      from 
(select
      user_id
      ,ip 
 from dms.user_login_log
group by user_id,ip)  A1
join
(select
     user_id
     ,ip 
 from dms.user_login_log
group by user_id,ip) A2 
ON A1.ip = A2.ip
where A1.user_id>A2.user_id
group by A1.user_id,A2.user_id
having count(1)>=3

实现效果如下:
请添加图片描述

最近更新

  1. TCP协议是安全的吗?

    2023-12-08 12:44:04       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-08 12:44:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-08 12:44:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-08 12:44:04       20 阅读

热门阅读

  1. 力扣面试150题 | 88.合并两个有序数组

    2023-12-08 12:44:04       30 阅读
  2. 使用qemu-nbd挂载qcow2/raw磁盘文件

    2023-12-08 12:44:04       45 阅读
  3. CentOS 7.9安装zabbix5.0.39LTS版本

    2023-12-08 12:44:04       30 阅读
  4. 力扣labuladong——一刷day68

    2023-12-08 12:44:04       39 阅读
  5. Python:核心知识点整理大全7-笔记

    2023-12-08 12:44:04       32 阅读
  6. Flask中redis的配置与使用

    2023-12-08 12:44:04       39 阅读
  7. 1-Hadoop原理与技术

    2023-12-08 12:44:04       33 阅读
  8. Pytorch当中transpose()和permute()函数的区别

    2023-12-08 12:44:04       40 阅读
  9. 最新PyTorch机器学习与深度学习实践技术应用

    2023-12-08 12:44:04       40 阅读
  10. InterLM代码解析

    2023-12-08 12:44:04       34 阅读