SQL典型练习题

with可以解决很多想用子表解决的问题

over可以加想加的,改变表的结构

例题:

表(driver)说明:司机登录登出明细表,由于同一司机有可能同时登录两个司机端,所以同一时间段一个司机有可能会产生两条或者更多条数据。

字段名 描述 类型:

driver_id 司机id bigint

login 登录时间 yyyy-mm-dd HH:MM:SS

exit 下线时间 yyyy-mm-dd HH:MM:SS

题目:请你统计2024年8月1日后的所有司机在线时长,要求对司机时间去重,每个司机在线时长精确到秒。

注:我们保证在8月1日0时做了一次司机清场,即保证不会有司机8月1日之前登录8月1日之后退出的情况出现。

法一:利用lead()加一列有效退出时间

法二:with语句

复制代码
WITH driver_time AS (
    SELECT driver_id, login AS event_time, 1 AS flag
    FROM driver
    WHERE login >= '2024-08-01'
    UNION ALL
    SELECT driver_id, exit AS event_time, -1 AS flag
    FROM driver
    WHERE exit >= '2024-08-01'
    -- 给出登录和登出的标志
),
driver_status AS (
    SELECT 
        driver_id,
        event_time,
        SUM(flag) OVER (PARTITION BY driver_id ORDER BY event_time) AS online_status
    FROM driver_time
    -- 给出在线状态
),
driver_intervals AS (
    SELECT 
        driver_id,
        event_time AS start_time,
        LEAD(event_time) OVER (PARTITION BY driver_id ORDER BY event_time) AS end_time,
        online_status
    FROM driver_status
    -- 用了lead()
)
SELECT 
    driver_id,
    SUM(TIMESTAMPDIFF(SECOND, start_time, end_time)) AS total_online_duration_seconds
FROM driver_intervals
WHERE online_status > 0
AND end_time IS NOT NULL
GROUP BY driver_id;

driver_id event_time flag online_status end_time

001 '2024-08-01 07:00:00' 1 1 '2024-08-01 08:00:00'

001 '2024-08-01 08:00:00' 1 2 '2024-08-01 09:00:00'

001 '2024-08-01 09:00:00' -1 1 '2024-08-01 10:00:00'

001 '2024-08-01 10:00:00' -1 0 '2024-08-01 11:00:00'

001 '2024-08-01 11:00:00' 1 1 '2024-08-01 12:00:00'

001 '2024-08-01 12:00:00' -1 0 null

相关推荐
爱莉希雅&&&12 小时前
Docker 部署 MySQL 双主双从同步架构详细笔记
linux·运维·数据库·mysql·docker·架构·主从同步
Polar__Star14 小时前
如何结合计划任务实现自动定时备份任务配置_全自动化运维管理
jvm·数据库·python
weixin_5806140019 小时前
如何提取SQL日期中的年份_使用YEAR或EXTRACT函数
jvm·数据库·python
2301_8135995519 小时前
SQL生产环境规范_数据库使用最佳实践
jvm·数据库·python
a95114164219 小时前
Go 中通过 channel 传递切片时的数据竞争与深拷贝解决方案
jvm·数据库·python
qq_1898070320 小时前
如何修改RAC数据库名_NID工具在集群环境下的改名步骤
jvm·数据库·python
aXin_ya20 小时前
Redis 高级篇(最佳实践)
数据库·redis·缓存
zhangchaoxies20 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
zhangchaoxies20 小时前
CSS如何实现响应式弹性网格布局_配合media query修改flex-wrap属性
jvm·数据库·python
霖霖总总20 小时前
[Redis小技巧32]Redis分布式锁的至暗时刻:从原理演进到时钟跳跃的终极博弈
数据库·redis·分布式