需求
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 表示广告出现的时间点
请查出,所有没有广告出现过的剧集。
如果观众观看了剧集,并且剧集里出现了广告,就一定会有观众观看广告的记录。
返回结果没有顺序要求。
输入
输出
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 ;