经典sql题(三)查找股票价格波峰波谷

了解价格的波动情况对市场决策至关重要,本文通过 SQL 查询,演示如何从一个价格数据表中提取价格波动信息,识别出波峰和波谷。我们假设有一个名为 test 的表,包含每个时间点的价格数据。

示例数据

假设我们的 test 表有以下数据:

id ds price
1 2023-10-01 08:00:00 100
1 2023-10-01 09:00:00 110
1 2023-10-02 10:00:00 105
1 2023-10-03 11:00:00 115
2 2023-10-01 10:00:00 200
2 2023-10-02 12:00:00 190
2 2023-10-03 14:00:00 195
2 2023-10-04 15:00:00 210
3 2023-10-01 16:00:00 300

查询步骤

第一步:计算前后价格

我们将使用窗口函数 LAGLEAD 来获取每个价格点的前后价格。

sql 复制代码
SELECT 
    id,
    ds,
    price,
    LAG(price, 1) OVER (PARTITION BY id ORDER BY ds) AS lag_price,
    LEAD(price, 1) OVER (PARTITION BY id ORDER BY ds) AS lead_price
FROM 
    test;

结果(中间表):

id ds price lag_price lead_price
1 2023-10-01 08:00:00 100 NULL 110
1 2023-10-01 09:00:00 110 100 105
1 2023-10-02 10:00:00 105 110 115
1 2023-10-03 11:00:00 115 105 NULL
2 2023-10-01 10:00:00 200 NULL 190
2 2023-10-02 12:00:00 190 200 195
2 2023-10-03 14:00:00 195 190 210
2 2023-10-04 15:00:00 210 195 NULL
3 2023-10-01 16:00:00 300 NULL NULL
第二步:识别波峰与波谷

在获取前后价格的基础上,我们接着使用 CASE 语句来标记波峰和波谷。

sql 复制代码
SELECT 
    id,
    ds,
    price,
    CASE 
        WHEN price > lag_price AND price > lead_price THEN '波峰'
        WHEN price < lag_price AND price < lead_price THEN '波谷'
        ELSE '无'
    END AS price_type
FROM (
    SELECT 
        id,
        ds,
        price,
        LAG(price, 1) OVER (PARTITION BY id ORDER BY ds) AS lag_price,
        LEAD(price, 1) OVER (PARTITION BY id ORDER BY ds) AS lead_price
    FROM 
        test
) AS subquery;

结果(最终结果):

id ds price price_type
1 2023-10-01 08:00:00 100
1 2023-10-01 09:00:00 110 波峰
1 2023-10-02 10:00:00 105 波谷
1 2023-10-03 11:00:00 115
2 2023-10-01 10:00:00 200
2 2023-10-02 12:00:00 190 波谷
2 2023-10-03 14:00:00 195
2 2023-10-04 15:00:00 210
3 2023-10-01 16:00:00 300

完整步骤解析

  1. 计算前后价格

    • 使用 LAGLEAD 函数,基于每个 id 的时间顺序提取前后价格。
  2. 识别波峰与波谷

    • 使用 CASE 语句判断当前价格的波动状态,标记为"波峰"、"波谷"或"无"。
相关推荐
无响应de神几秒前
三、用户与权限管理
数据库·mysql
大树8815 小时前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
大志哥12316 小时前
ES和Logstash日志链路系统上线后遭遇切片爆炸(解决)
大数据·elasticsearch
果丁智能17 小时前
物联网智能锁赋能集中式住宿:身份核验与远程权限管控的全链路技术实践
大数据·人工智能·物联网·智能家居
麦聪聊数据17 小时前
数据服务化时代:企业数据能力输出的核心路径
数据库
ApacheSeaTunnel18 小时前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
shushangyun_18 小时前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡18 小时前
【MySQL数据库】数据类型与表约束
数据库·mysql
weixin_3975740918 小时前
PDF复杂表格的1:1还原引擎:跨页表格自动拼接技术实战
大数据·人工智能·pdf
极光代码工作室18 小时前
基于数据仓库的电商数据分析平台
大数据·hadoop·python·spark·数据可视化