RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1361239
Accepted
Radzhab
Radzhab
Asked:2022-05-15 16:21:35 +0000 UTC2022-05-15 16:21:35 +0000 UTC 2022-05-15 16:21:35 +0000 UTC

如何从数据中获取第一个和最后一个值?

  • 772

这里有张桌子。我想按索引分割这个范围,并从中获取第一个值和最后一个值。

datetime,index

1633378385000,4
1633378451000,4
1633378505000,4
1633378582000,4
1633378652000,4
1633378717000,4
1633378782000,""
1633378848000,""
1633378913000,""
1633383874000,""
1633383940000,5
1633384007000,5
1633384011000,5
1633384205000,5
1633384266000,5
1633384340000,5
1633387730000,""
1633387750000,""
1633388380000,4
1633389103000,4
1633389181000,4
1633389247000,4

输出应该是

1633378385000,4
1633378717000,4
1633383940000,5
1633384340000,5
1633388380000,4
1633389247000,4

我想用first_value-来做last_value,但它会查看整个表格,但我需要它一块一块地。

在此处输入图像描述

sql
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Akina
    2022-05-15T16:44:05Z2022-05-15T16:44:05Z

    MySQL 8+ 版本的解决方案:

    WITH 
    cte1 AS ( SELECT *, `index` <> LAG(`index`) OVER (ORDER BY `datetime`) newgroup
              FROM test ),
    cte2 AS ( SELECT *, COALESCE(SUM(newgroup) OVER (ORDER BY `datetime`), 0) groupnum
              FROM cte1 )
    SELECT MIN(`datetime`) datetime_start,
           MAX(`datetime`) datetime_end,
           ANY_VALUE(`index`) `index`
    FROM cte2
    WHERE `index`
    GROUP BY groupnum
    ORDER BY 1;
    

    或者

    
    WITH 
    cte AS ( SELECT *,
                    COALESCE(LAG(`index`) OVER (ORDER BY `datetime`), '') previousindex,
                    COALESCE(LEAD(`index`) OVER (ORDER BY `datetime`), '') nextindex 
             FROM test )
    SELECT `datetime`, `index`
    FROM cte
    WHERE '' IN (previousindex, nextindex)
     AND `index` <> '' 
    ORDER BY 1;
    

    https://dbfiddle.uk/?rdbms=mysql_8.0&fiddle=e6104479de1664121d560f2629c3a3b5

    PS。该任务是标准的,称为“间隙和岛屿”。

    • 1

相关问题

  • 通过 OUT 参数从过程结果输出

  • ON 关键字附近的语法错误 - SQL

  • 多表查询中的 Count() 聚合函数

  • 根据时间更改单元格中的日期

  • phpMyAdmin 中的错误 #1064 SQL 查询

  • Qt:包含变量的数据库查询

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5