力扣1809 没有广告的剧集(postgresql)

需求

Table: Playback

±------------±-----+

| Column Name | Type |

±------------±-----+

| session_id | int |

| customer_id | int |

| start_time | int |

| end_time | int |

±------------±-----+

该表主键为:session_id (剧集id)

customer_id 是观看该剧集的观众id

剧集播放时间包含start_time(开始时间) 及 end_time(结束时间)

可以保证的是,start_time(开始时间)<= end_time(结束时间),一个观众观看的两个剧集的时间不会出现重叠。

Table: Ads

±------------±-----+

| Column Name | Type |

±------------±-----+

| ad_id | int |

| customer_id | int |

| timestamp | int |

±------------±-----+

该表的主键为:ad_id(广告id)

customer_id 为 观看广告的用户id

timestamp 表示广告出现的时间点

请查出,所有没有广告出现过的剧集。

如果观众观看了剧集,并且剧集里出现了广告,就一定会有观众观看广告的记录。

返回结果没有顺序要求。

输入

输出

sql 复制代码
with t1 as (
-- 两表左外连接,筛选出广告时间在剧集时间之外的数据
select session_id,a.customer_id,start_time,end_time,ad_id,timestamp
from playback p left join ads a
on p.customer_id = a.customer_id
and (timestamp<start_time or timestamp>end_time)
)
-- 排除掉上步查询结果为空的数据,对求出来的剧集id去重
select distinct session_id
from t1
where timestamp notnull ;
相关推荐
棱镜Coding6 分钟前
LeetCode-Hot100 30.两两交换链表中的节点
算法·leetcode·链表
躲在云朵里`9 分钟前
更新时对字段的重复校验
数据库·oracle
阿kun要赚马内11 分钟前
Qt写群聊项目(一):服务器
服务器·数据库·qt
2301_7903009612 分钟前
C++与量子计算模拟
开发语言·c++·算法
康小庄12 分钟前
SpringBoot 拦截器 (Interceptor) 与切面 (AOP):示例、作用、及适用场景
java·数据库·spring boot·后端·mysql·spring·spring cloud
汽车仪器仪表相关领域22 分钟前
经典指针+瞬态追踪:MTX-A模拟废气温度(EGT)计 改装/赛车/柴油车排气温度监测实战全解
大数据·功能测试·算法·机器学习·可用性测试
小六花s26 分钟前
SQL注入笔记
数据库·笔记·sql
yufuu9827 分钟前
Python在金融科技(FinTech)中的应用
jvm·数据库·python
如果你想拥有什么先让自己配得上拥有29 分钟前
斐波那契黄金分割自然界演化以及金融上的共振?
算法·金融
灰色小旋风31 分钟前
力扣第1题:两数之和(C++)
c++·算法