手撕sql面试题:找出所有观看视频ID “1001“ 的观看时长大于他们观看视频ID “1002“ 的观看时长的用户ID

本文介绍了一个SQL面试题目,要求找出观看视频ID为1001且观看时长大于1002的所有用户的ID。通过自连接video_records表并使用WHERE和DISTINCT关键字实现查询。
摘要由CSDN通过智能技术生成



        分享最近面试的sql面试题:

        下面是表结构:
        CREATE TABLE `video_records` (
  `video_id` char(4) NOT NULL COMMENT '视频id',
  `user_id` char(4) NOT NULL COMMENT '用户id',
  `play_duration` int NOT NULL COMMENT '观看时长',
  PRIMARY KEY (`video_id`,`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

        示例数据:
        insert into video_records value ("1001","A001",200)
        insert into video_records value ("1001","B001",300)

        insert into video_records value ("1002","A001",488)

        insert into video_records value ("1002","B001",270)

        insert into video_records value ("1003","A001",234)

         编写sql语句,要求:查找所有观看视频ID"1001"的观看时长大于视频ID“1002”的观看时长的用户ID 

        思路:

  1. 使用自连接(JOIN)将video_views表自身连接起来,基于user_id匹配相同的用户在观看不同视频的记录。
  2. WHERE子句限定了我们只关心那些视频ID分别为"1001"和"1002"的记录,并要求"1001"的观看时长大于"1002"的。
  3. DISTINCT关键字确保每个符合条件的用户ID只被列出一次,避免重复
SELECT  distinct vv1.user_id
FROM video_records vv1
JOIN video_records vv2 ON vv1.user_id = vv2.user_id  WHERE vv1.video_id = "1001" AND vv2.video_id = "1002"
 and vv1.play_duration > vv2.play_durationvideo_records

 执行结果:


         


感谢各位的观看,创作不易,能不能给哥们来一个点赞呢!!!

好了,今天的分享就这么多了,有什么不清楚或者我写错的地方,请多多指教!

私信,评论我呗!!!!!! 

关注我下一篇不迷路哦!

  • 8
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值