- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试找到关于在给定时间间隔内获取第一个元素和最后一个元素的最有效方法的答案。我有一个与 device
表相关的表 interval_data
(包括物联网数据)。我想获得每个设备的第一个和最后一个元素的结果。
区间数据表:
id device_id created_at value
15269665 1000206 2018-07-21 00:10:00 5099.550000
15270533 1000206 2018-07-21 00:20:00 5099.610000
15271400 1000206 2018-07-21 00:30:00 5099.760000
15272269 1000206 2018-07-21 00:40:00 5099.850000
15273132 1000206 2018-07-21 00:50:00 5099.910000
15274040 1000206 2018-07-21 01:00:00 5099.970000
15274909 1000206 2018-07-21 01:10:00 5100.030000
15275761 1000206 2018-07-21 01:20:00 5100.110000
15276629 1000206 2018-07-21 01:30:00 5100.160000
15277527 1000206 2018-07-21 01:40:00 5100.340000
15278351 1000206 2018-07-21 01:50:00 5100.400000
15279219 1000206 2018-07-21 02:00:00 5100.450000
15280085 1000206 2018-07-21 02:10:00 5100.530000
15280954 1000206 2018-07-21 02:20:00 5100.590000
15281858 1000206 2018-07-21 02:30:00 5100.640000
15282724 1000206 2018-07-21 02:40:00 5100.750000
15283627 1000206 2018-07-21 02:50:00 5100.870000
15284495 1000206 2018-07-21 03:00:00 5100.930000
... ... ... ...
我尝试了一些查询,例如:
select created_at, value from interval_data i inner join
(select min(created_at) minin, max(created_at) maxin, d.device_id from device
d
inner join interval_data i on i.device_id = d.device_id
where d.device_id in (1000022, 1000023, 1000024)
and i.created_at between '2018-01-01 00:00:00' and '2019-01-01 00:00:00'
group by d.device_id) s
on s.device_id = i.device_id and (s.minin = i.created_at or s.maxin =
i.created_at)
但是当设备数量增加时,响应时间会变长。你有什么建议吗?如何更快地找到每个设备的第一个和最后一个元素?
最佳答案
最有效的查询取决于您的设置细节。 通常,具有两个LATERAL
子查询的查询应该是最快的:
SELECT * -- or just the columns you need
FROM device d
LEFT JOIN LATERAL (
SELECT id AS first_intv_id, created_at AS first_created_at, value AS first_value
FROM interval_data
WHERE device_id = d.id
ORDER BY created_at
LIMIT 1
) f ON true
LEFT JOIN LATERAL (
SELECT id AS last_intv_id, created_at AS last_created_at, value AS last_value
FROM interval_data
WHERE device_id = d.id
ORDER BY created_at DESC -- NULLS LAST if column isn't NOT NULL
LIMIT 1
) l ON true;
Postgres 可以将其转换为仅对大表 interval_data
进行快速索引扫描的查询计划。
关于横向
:
确保在 interval_data(device_id, created_at)
上有一个索引。如果您只需要结果中的一组有限列,则可能需要将更多列附加到该索引以从中获取仅索引扫描。
LEFT JOIN ... ON true
保留结果中没有间隔数据的设备。
要限制给定的一组设备 ID,请附加到查询中:
...
WHERE d.id IN (1000022, 1000023, 1000024);
并且在 device(id)
上有一个索引——无论如何这都是典型的情况。
假设当前的 Postgres 版本和这样的设置:
CREATE TABLE device (
id serial PRIMARY KEY
, device text NOT NULL
);
CREATE TABLE interval_data (
id serial PRIMARY KEY
, device_id int NOT NULL
, created_at timestamp NOT NULL
, value numeric NOT NULL
, CONSTRAINT device_fkey FOREIGN KEY (device_id) REFERENCES device (id)
);
如果一些涉及的列没有定义NOT NULL
,你可能需要调整细节。
对于此解决方案,FK 约束是可选的。
备选方案的详细解释和讨论:
使用带有自定义窗口框架的窗口函数可以在没有单独的表设备
的情况下完成,并且对于一小组ID可能更快:
SELECT DISTINCT ON (device_id)
device_id
, first_value(created_at) OVER w AS first_created_at
, first_value(value) OVER w AS first_value
, last_value (created_at) OVER w AS last_created_at
, last_value (value) OVER w AS last_value
FROM interval_data
WHERE device_id IN (1000022, 1000023, 1000024)
WINDOW w AS (PARTITION BY device_id ORDER BY created_at
ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING);
与上面的第一个查询相同:
但是与上面的第一个查询不同:
关于窗框:
关于sql - 如何获取每个设备的第一个和最后一个元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51454810/
我需要您在以下方面提供帮助。近一个月来,我一直在阅读有关任务和异步的内容。 我想尝试在一个简单的 wep api 项目中实现我新获得的知识。我有以下方法,并且它们都按预期工作: public Htt
我的可执行 jar 中有一个模板文件 (.xls)。不需要在运行时我需要为这个文件创建 100 多个副本(稍后将唯一地附加)。用于获取 jar 文件中的资源 (template.xls)。我正在使用
我在查看网站的模型代码时对原型(prototype)有疑问。我知道这对 Javascript 中的继承很有用。 在这个例子中... define([], function () { "use
影响我性能的前三项操作是: 获取滚动条 获取偏移高度 Ext.getStyle 为了解释我的应用程序中发生了什么:我有一个网格,其中有一列在每个单元格中呈现网格。当我几乎对网格的内容做任何事情时,它运
我正在使用以下函数来获取 URL 参数。 function gup(name, url) { name = name.replace(/[\[]/, '\\\[').replace(/[\]]/,
我最近一直在使用 sysctl 来做很多事情,现在我使用 HW_MACHINE_ARCH 变量。我正在使用以下代码。请注意,当我尝试获取其他变量 HW_MACHINE 时,此代码可以完美运行。我还认为
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关闭 9 年前。 要求提供代码的问题必须表现出对所解决问题的最低限度的理解。包括尝试过的解决方案、为什么
由于使用 main-bower-files 作为使用 Gulp 的编译任务的一部分,我无法使用 node_modules 中的 webpack 来require 模块code> dir 因为我会弄乱当
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 5 年前。 Improve this qu
我使用 Gridlayout 在一行中放置 4 个元素。首先,我有一个 JPanel,一切正常。对于行数变大并且我必须能够向下滚动的情况,我对其进行了一些更改。现在我的 JPanel 上添加了一个 J
由于以下原因,我想将 VolumeId 的值保存在变量中: #!/usr/bin/env python import boto3 import json import argparse import
我正在将 MSAL 版本 1.x 更新为 MSAL-browser 的 Angular 。所以我正在尝试从版本 1.x 迁移到 2.X.I 能够成功替换代码并且工作正常。但是我遇到了 acquireT
我知道有很多关于此的问题,例如 Getting daily averages with pandas和 How get monthly mean in pandas using groupby但我遇到
This is the query string that I am receiving in URL. Output url: /demo/analysis/test?startDate=Sat+
我正在尝试使用 javascript 中的以下代码访问 Geoserver 层 var gkvrtWmsSource =new ol.source.ImageWMS({ u
API 需要一个包含授权代码的 header 。这就是我到目前为止所拥有的: var fullUrl = 'https://api.ecobee.com/1/thermostat?json=\{"s
如何获取文件中的最后一个字符,如果是某个字符,则删除它而不将整个文件加载到内存中? 这就是我目前所拥有的。 using (var fileStream = new FileStream("file.t
我是这个社区的新手,想出了我的第一个问题。 我正在使用 JSP,我成功地创建了 JSP-Sites,它正在使用jsp:setParameter 和 jsp:getParameter 具有单个字符串。
在回答 StoreStore reordering happens when compiling C++ for x86 @Peter Cordes 写过 For Acquire/Release se
我有一个函数,我们将其命名为 X1,它返回变量 Y。该函数在操作 .on("focusout", X1) 中使用。如何获取变量Y?执行.on后X1的结果? 最佳答案 您可以更改 Y 的范围以使其位于函
我是一名优秀的程序员,十分优秀!