- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我编写了一个 SQL 例程,用于根据 5 天的数据(天数是例程的参数)计算一天中每一分钟的平均值,并将结果插入到另一个表中。太长了,我想知道是否有任何方法可以优化它。
我需要用来计算平均值的值都在同一个表 SiteReading 中,因此为了获取同一分钟但来自不同日期的 5 个值,我加入了这些天的表子集,以便小时和分钟匹配然后这些值最终会出现在同一行。然后,我在每行上添加 5 个值,并从中创建一个新表,并将其插入到存储这些平均值的基线表中。
这是例程:
CREATE PROCEDURE 'calc_baseline` (IN `input_site_id` int, IN `day1` varchar(12), IN `day2` varchar(12), IN `day3` varchar(12), IN `day4` varchar(12), IN `day5` varchar(12))
BEGIN
insert into Baseline
SELECT
site_id,
contract_id,
temp_time as timestamp,
(sr1value + sr2value + sr3value + sr4value + sr5value) / 5 as value,
programme
FROM
(SELECT
distinct concat(cast(hour(temp_time) as char), ':', cast(minute(temp_time) as char)) as hourminute,
SR.site_id as site_id,
value as sr1value,
temp_time,
S.contract_id as contract_id,
programme
FROM
SiteReading SR
join Site S ON SR.site_id = S.site_id
join Contract C ON S.contract_id = C.contract_id
where
temp_time like 'day1%'
and SR.site_id = input_site_id) sr1
join
(SELECT
concat(cast(hour(temp_time) as char), ':', cast(minute(temp_time) as char)) as hourminute,
value as sr2value
FROM
SiteReading
where
temp_time like 'day2%'
and site_id = input_site_id) sr2 ON sr1.hourminute = sr2.hourminute
join
(SELECT
concat(cast(hour(temp_time) as char), ':', cast(minute(temp_time) as char)) as hourminute,
value as sr3value
FROM
SiteReading
where
temp_time like 'day3%'
and site_id = input_site_id) sr3 ON sr1.hourminute = sr3.hourminute
join
(SELECT
concat(cast(hour(temp_time) as char), ':', cast(minute(temp_time) as char)) as hourminute,
value as sr4value
FROM
SiteReading
where
temp_time like 'day4%'
and site_id = input_site_id) sr4 ON sr1.hourminute = sr4.hourminute
join
(SELECT
concat(cast(hour(temp_time) as char), ':', cast(minute(temp_time) as char)) as hourminute,
value as sr5value
FROM
SiteReading
where
temp_time like 'day5%'
and site_id = input_site_id) sr5 ON sr1.hourminute = sr5.hourminute
limit 1440;
END//
DELIMITER ;
<小时/>
它正在读取和写入的相关表是:
- 网站阅读:
CREATE TABLE `SiteReading` (
`site_id` int(11) NOT NULL,
`contract_id` int(11) DEFAULT NULL,
`temp_time` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
`value` int(11) NOT NULL,
PRIMARY KEY (`site_id`,`temp_time`),
KEY `site_id` (`site_id`),
KEY `contract_id` (`contract_id`),
CONSTRAINT `SiteReading_ibfk_1` FOREIGN KEY (`site_id`) REFERENCES `Site` (`site_id`),
CONSTRAINT `SiteReading_ibfk_3` FOREIGN KEY (`contract_id`) REFERENCES `Contract` (`contract_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8$$
- 基线:
CREATE TABLE `Baseline` (
`site_id` int(11) NOT NULL,
`contract_id` int(11) NOT NULL,
`timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`value` int(11) NOT NULL,
`programme` int(11) NOT NULL,
PRIMARY KEY (`site_id`,`timestamp`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8$$
因为我需要获取一些附加值(site_id、contract_id、programme)来存储在基线中,这些值对于每一行都相同,所以我想知道也许我应该以其他方式执行插入语句?问题是基线表的所有列都不能为空。
也许有人对此过程有任何其他评论 - 我是否需要为此例程定义一些其他参数,例如 ON DUPLICATE KEY UPDATE 或其他与例程相关的内容?
谢谢。
最佳答案
SELECT
t1.site_id,
t1.contract_id,
t1.temp_time,
AVG(t2.value)
FROM
SiteReading AS t1
LEFT JOIN
SiteReading AS t2
ON
t1.site_id = t2.site_id
AND t2.datetime BETWEEN startdate AND enddate
AND HOUR(t1.temp_time) = HOUR(t2.temp_time)
AND MINUTE(t1.temp_time) = MINUTE(t2.temp_time)
WHERE
t1.temp_time BETWEEN startdate AND enddate
GROUP BY
t1.site_id,
t1.contract_id,
t1.temp_time
根本没有测试过,但是这样的东西可能会更好地为你服务。我所做的优化:
1.Because I need to get some additional values (site_id, contract_id, programme) to store in the Baseline that are the same for each row I was wondering that maybe I should do the insert statement in some other way? the thing is that all of the Baseline table's columns can not be null.
参见#4
2.Maybe someone has any other comments about this procedure - do I need to define some other parameters for this routine like ON DUPLICATE KEY UPDATE or some other routine related things?
不确定我是否完全理解您的要求。您是否在较长时间内收集多个 5 天基线?如果是这样,我不明白为什么您需要更新任何内容。如果某些 temp_time 重叠(即,在 5 天的时间内运行过程的频率高于每 5 天一次),那么您可以保留唯一的 ID 或时间戳作为基线主键的一部分,以标识运行过程的时间,以防止重复键在 temp_time 上。
我现在才发现你的日子可能不是连续的。在这种情况下,更改这些行:
AND t2.datetime BETWEEN startdate AND enddate
t1.temp_time BETWEEN startdate AND enddate
至:
AND DATE(t2.datetime) IN (day1, day2, day3, day4, day5)
DATE(t1.temp_time) IN (day1, day2, day3, day4, day5)
但是,这会带来一个问题,因为您现在必须在 WHERE 子句和 ON 条件下对站点读取进行全表扫描。为了避免这种情况,您可以考虑在存储数据集之前规范化数据集的时间间隔。例如,如果每天读取 24*60 个读数,则每个 temp_time 间隔可以用 1 到 1440 的 int 表示,每天可以用 1 到 365(366 闰年)的 int 表示。然后在 where 和 join 子句中使用这些值。
关于mysql - 优化计算一天中每一分钟平均值的 SQL 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13994140/
我有一个大小为 320x320 像素的阈值图像。我通过设置 ROI 以 20x20 像素的 block 循环遍历整个图像。我需要找到每个 block 的平均值。所以我将这些图像 block 传递给函数
我正在尝试学习 Javascript。我已经构建了以下代码来从一组数字中找到平均值。它有效除了最后返回的值总是 NaN。我不知道为什么。如果我将这 block 移到 block 外,它似乎完全忘记了变
假设我的数据已经分组,我该如何计算中位数和其他统计数据? Index Value Count 0 6 2 1 2 3 2 9 8 在上面
我试图计算的有趣情况。基本上在一行中,我有产品名称,其右侧的行是自首次收到产品以来经过的天数。 为 ex 计算的天数是 =TODAY()-BB2 我现在要做的是识别让我们说产品词“卡车”,然后计算卡车
我想知道如何计算某些数字的累积平均值。我将举一个简单的例子来描述我在寻找什么。 我有以下号码 vec 1) 为您的向量(或列表、一维数组或您如何称呼它)的每个元素评估此表达式,您将获得累积平均值。
我正在尝试对数据库表中的每一行进行平均。但它不能正常工作我想忽略该值,如果为空,它不会计算为零。使用我的代码,它将空值计算为零我想这样做 MS Excel 如果行/单元格为空,它将忽略。 Contro
我有以下信息(按 View 返回): DateTime ItemID UserTyp Seconds 2012-01-01 10 S 12 2012-01-01
我正在使用excel的average函数来获取欧洲各个城市一系列酒店价格的平均值。 =average(21,42,63,84,105) 我希望能够计算每个平均函数中的变量数量(例如,在上面的示例中有
我有一长串列,我想一次性计算非零中位数、平均值和标准差。我不能只删除基于 1 列的 0 行,因为同一列中另一列的值可能不是 0。 下面是我目前的代码,用于计算中位数、平均值等,包括零。 agg
这是我的问题: 我有一张这样的 table : Table Log int id; int time; timestamp DATE; int sid (FK to table Site);
JSON: [{"id":"1","user":"001","answer":"1,1,3,2,2,1,3,2"}, {"id":"2","user":"002","answer":"2,3,3,2,
有个问题: 使用适当的列名称,显示 obs 类型“CONT”的允许 ID 和平均 obs 值,其中 CONT 的平均 obs 值 >= 40。 假设承认是表1,观察是表2,但具有相同的主键Admit_
我有一个记录传感器数据的应用程序,我希望能够从多个传感器生成平均值,可以是一个、两个、三个或很多... 编辑:这些是温度传感器,因此 0 是传感器可能作为值存储在数据库中的值。 我最初的出发点是这个
我有这样一个数据框 id power flag 0 20 0 1 25 0 2 26 1 3 30 1 4 18 0 5
我想计算所有事件 blob 的平均位置。为此,首先我需要所有 X 和 Y 位置的总和。在这种情况下我该怎么做? contourFinder.findContours(grayImg, minB
我是一个十足的 Java 新手。上周一开始,之前从未用任何语言进行过任何编程。因此,如果我发现简单的事情变得复杂,请耐心等待。 我收到了一个文本文件。如下图: 第一个数据是时间(午夜过后的秒数),第二
我正在尝试为 Audacity 编写一个简单的测量插件,它就像用石头砸我的头骨一样有趣。我想要做的就是获取一段音频并找到所有样本的平均值(该 block 的 DC offset ),这样我就可以将它作
我正在尝试计算给定多边形内的值: 实际上我正在使用这个管道: 'aggregation': { 'pipeline': [ { "$match" : {
我有一个 pandas DataFrame,其中包含包含列表的列。我正在尝试获取此专栏中列表的方法。 这是我的 DataFrame 的示例: Loc Background 0
我尝试加速计算放置在数组中的4d向量的平均值。这是我的代码: #include #include #include #include #include #include typedef f
我是一名优秀的程序员,十分优秀!