- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个数据集,用于跟踪手机电池电量和连接的快照。然而,当手机失去连接时,它会报告与上次良好连接相同的数字,例如:
id timestamp connection bat_level
1 1 2019-09-12 20:00:00 TRUE 4
2 1 2019-09-12 20:05:00 TRUE 4
3 1 2019-09-12 20:10:00 TRUE 4
4 1 2019-09-12 20:15:00 TRUE 4
5 1 2019-09-12 20:20:00 TRUE 3
6 1 2019-09-12 20:25:00 FALSE 3
7 1 2019-09-12 20:30:00 FALSE 3
8 1 2019-09-12 20:35:00 FALSE 3
9 1 2019-09-12 20:40:00 FALSE 3
10 1 2019-09-12 20:45:00 FALSE 3
11 1 2019-09-12 20:50:00 FALSE 3
12 1 2019-09-12 20:55:00 FALSE 3
13 1 2019-09-12 21:00:00 TRUE 1
14 1 2019-09-12 21:05:00 TRUE 1
15 1 2019-09-12 21:10:00 FALSE 1
16 1 2019-09-12 21:15:00 FALSE 1
17 1 2019-09-12 21:20:00 FALSE 1
18 1 2019-09-12 21:25:00 FALSE 1
19 1 2019-09-12 21:30:00 FALSE 1
20 1 2019-09-12 21:35:00 FALSE 1
21 1 2019-09-12 21:40:00 FALSE 1
22 1 2019-09-12 21:45:00 FALSE 1
23 1 2019-09-12 21:50:00 FALSE 1
24 1 2019-09-12 21:55:00 FALSE 1
25 1 2019-09-12 22:00:00 FALSE 1
我的目标是创建第五列,该列基本上插入 connection
= FALSE 时发生的情况。我想从 last TRUE connection 的值开始以每分钟 0.05 的速度插入电池消耗率(不能低于 0),因此输出将是:
id timestamp connection bat_level theoretical_bat_level
1 1 2019-09-12 20:00:00 TRUE 4 NA
2 1 2019-09-12 20:05:00 TRUE 4 NA
3 1 2019-09-12 20:10:00 TRUE 4 NA
4 1 2019-09-12 20:15:00 TRUE 4 NA
5 1 2019-09-12 20:20:00 TRUE 3 NA
6 1 2019-09-12 20:25:00 FALSE 3 2.75
7 1 2019-09-12 20:30:00 FALSE 3 2.50
8 1 2019-09-12 20:35:00 FALSE 3 2.25
9 1 2019-09-12 20:40:00 FALSE 3 2.00
10 1 2019-09-12 20:45:00 FALSE 3 1.75
11 1 2019-09-12 20:50:00 FALSE 3 1.50
12 1 2019-09-12 20:55:00 FALSE 3 1.25
13 1 2019-09-12 21:00:00 TRUE 1 NA
14 1 2019-09-12 21:05:00 TRUE 1 NA
15 1 2019-09-12 21:10:00 FALSE 1 0.75
16 1 2019-09-12 21:15:00 FALSE 1 0.50
17 1 2019-09-12 21:20:00 FALSE 1 0.25
18 1 2019-09-12 21:25:00 FALSE 1 0.00
19 1 2019-09-12 21:30:00 FALSE 1 0.00
20 1 2019-09-12 21:35:00 FALSE 1 0.00
21 1 2019-09-12 21:40:00 FALSE 1 0.00
22 1 2019-09-12 21:45:00 FALSE 1 0.00
23 1 2019-09-12 21:50:00 FALSE 1 0.00
24 1 2019-09-12 21:55:00 FALSE 1 0.00
25 1 2019-09-12 22:00:00 FALSE 1 0.00
我知道应该使用带有 lag()
的 cte,但不确定如何开始从最后一个 TRUE
开始降低 theoretical_bat_level
> 每个 id
CASE WHEN connection = FALSE AND
LAG(connection) OVER(PARTITION BY id, timestamp ASC) = True AND
connection = LAG(bat_level) OVER(PARTITION BY id, timestamp ASC) THEN ?
WHERE connection = FALSE
任何有关此处正确使用方法的指导都会有所帮助
最佳答案
我的解决方案需要一个辅助函数来计算间隔的长度(以分钟为单位):
CREATE OR REPLACE FUNCTION int_minutes(interval) RETURNS double precision
LANGUAGE sql STRICT IMMUTABLE AS
'SELECT EXTRACT (minutes FROM $1)
+ 60 * extract (hours FROM $1)
+ 1440 * extract (days FROM $1)';
然后你可以使用窗口函数来获取手机连接的最新时间:
SELECT id, timestamp, connection, bat_level,
greatest(bat_level
- int_minutes(timestamp
- conn_ts_arr[cardinality(conn_ts_arr)]
) * 0.05,
0.0
) AS theoretical_bat_level
FROM (SELECT id, timestamp, connection, bat_level,
array_agg(timestamp)
FILTER (WHERE connection)
OVER (PARTITION BY id
ORDER BY timestamp) AS conn_ts_arr
FROM cellbat) AS s1
ORDER BY id, timestamp;
关于sql - 在 SQL 中插入缺失值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57929059/
我编写了一个 Android 应用程序,它使用 Azure 来执行用户通过 Google、Twitter 和 Facebook 的登录;它使用 Microsoft.WindowsAzure.Mobil
我想将 AdomdClient 引用添加到 C# 项目,但它不在引用列表中。客户端列在程序集文件夹 C:\Windows\Assembly 中。 计算机上安装了 SQL Server 2012。 最佳
我正在学习“绘图应用程序”的教程。当我在 Firefox 上启动我的应用程序时,Firebug 告诉我“在语句之前缺少 ;” 我在第 9 行调用函数的位置。我只是不明白应该将这些“;”放在哪里. va
我想将 AdomdClient 引用添加到 C# 项目,但它不在引用列表中。客户端列在程序集文件夹 C:\Windows\Assembly 中。 计算机上安装了 SQL Server 2012。 最佳
我在 Firebug 中不断收到关于 onClick 事件的错误。 我已经尝试了 "和 ' 的各种不同组合,但无济于事。在添加 onClick 事件之前,这工作正常。 有人能发现我可能做错了什么吗?
Visual Studio 2015 告诉我找不到 WSASetSocketSecurity。 该 dll 存在并且还包括似乎没问题。 我的包括: windows.h stdio.h Wincrypt
我需要访问 eloquent 的 whereHasNot方法(此处添加: https://github.com/laravel/framework/commit/8f0cb08d8ebd157cbfe
跟随宠物物体检测的 TF 教程:https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/run
构建路径 > 添加库 > JUnit 无法添加 JUnit3 或 JUnit4 组件。 我在.log 中看到这样的消息 !MESSAGE No property tester contributes
我正在运行此脚本来查看网络上的摄像机: gst-launch udpsrc port=1234 ! "application/x-rtp, payload=127" ! rtph264depay !
我正在使用http://java.sun.com/jsp/jstl/fmt用于从 Spring 配置中设置的 Message Resource Bundle 输出消息的标签库。消息解析也可以放在 Co
我正在将 Ninject 与 MVC4 连接起来,并让它工作到尝试实际解决依赖关系的程度。但是,我收到以下异常: Method not found: 'System.Web.Http.Services
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 关闭 9 年前。 Improve
我在启动 ASP.NET MVC5 应用程序时遇到问题。到目前为止一切正常。启动应用程序时出现以下错误: Could not load file or assembly 'Microsoft.Appl
我已经使用以下方法创建了一个环境: conda create --prefix C:\Users\Dell\Dropbox\DjangoProjects\webenv python=3.6 执行后:c
我们有一个遗留的 Web 窗体应用程序,我们最近将其从网站项目转换为 Web 应用程序项目。 Web 窗体项目是解决方案的“启动”项目。 有一个 MVC 项目是对 Web 窗体项目的引用。 在 MVC
使用某种字体,我使用Java的FontLayout来确定它的上升、下降和行距。 (参见 Java 的 FontLayout 教程 here) 在我的具体案例中,我使用的是 Arial Unicode
我正在尝试在 linux 下编译 qt ffmpeg 包装器简单编码/解码示例 QTFFmpegWrapper source # Set list of required FFmpeg librari
我正在使用来自开发人员 android 页面的 SlidingTabLayout.java。在我使用 slidingTabLayout.setDistributeEvenly(true); 使 sli
我正在尝试使用 v360 filter 将 180° 鱼眼视频转换为普通/常规视频的 FFmpeg . 这是我尝试过的命令:ffmpeg -i in.mp4 -vf "v360=input=fishe
我是一名优秀的程序员,十分优秀!