- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
(PostgreSQL 9.3) 我有一个表“事件”,其中包含数百万个复杂事件,存储为设备接收到的事件。出于示例目的:
+-----------+-------+
| Timestamp | Event |
+-----------+-------+
| 1 | A |
| 2 | A |
| 2 | B |
| 3 | B |
| 10 | A |
| 11 | A |
| 11 | 0 |
| 11 | C |
| 12 | A |
+-----------+-------+
在这种情况下,我有四种不同类型的事件:A、B、C 和 0。我想做的是对它们进行索引,这样我就可以为每个事件设置开始/停止时间戳。停止条件是:不再在给定的时间戳上报告事件,或者“0”甚至进来,清除所有这些。最终输出:
+------+----+-------+
| From | To | Event |
+------+----+-------+
| 1 | 3 | A |
| 2 | 10 | B |
| 10 | 11 | A |
| 11 | 11 | C |
| 12 | | A |
+------+----+-------+
在这种情况下,A 在 1 时被提升,并在 3 时被清除,因为此时它不再被报告。由于类似的原因,B 在 2 点被加注,并在 10 点被清算。 A 在 10 点再次被引发并在 11 点被 0 事件清除(尽管当时也被报告了!)。 C 在 11 时被提升并同时被清除(需要进行一些排序以在同一时间戳处理 0)。最后,A 在 12 点再次被提升并且当前处于事件状态,因此它获得 NULL 结束时间戳。
我确实有一些有用的东西,但它的 CTE 很重,因此不能很好地扩展到数百万条记录。我一直在试验 LATERAL(取得了很好的结果)并且我愿意接受任何 9.3 特定的建议。此外,“事件”本身对于这个问题也进行了极大的简化,实际上它是一组复杂的列。窗口函数也可能适用于此。
最佳答案
这里跳出框框思考,为什么不用触发器来维护汇总表?
这是您的案例的示例(省略了 FK 等)
create table event_type (
event_type_id serial,
event_name varchar(255)
);
create table event (
event_time timestamp(0),
event_type_id int
);
create table event_summary (
event_summary_id serial,
sum_from timestamp(0),
sum_to timestamp(0),
event_type_id int
);
create language plpgsql;
create or replace function event_insertion() returns trigger as $$
declare
var_event_summary_id integer;
begin
-- find out if event was fired during the previous second
select
event_summary_id
into
var_event_summary_id
from
event_summary s
where
new.event_type_id = s.event_type_id
and sum_to >= new.event_time - interval '1 seconds';
if found then
--update existing summary to include this timestamp
update event_summary set sum_to = new.event_time where event_summary_id = var_event_summary_id;
else
--create new summary for just this timestamp
insert into event_summary(sum_from,sum_to,event_type_id) values (new.event_time,new.event_time,new.event_type_id);
end if;
return null;
end;
$$ language plpgsql;
create trigger event_insertion after insert on event
for each row execute procedure event_insertion();
-- some initial data
insert into event_type(event_name) values ('a');
insert into event_type(event_name) values ('b');
insert into event_type(event_name) values ('c');
insert into event_type(event_name) values ('0');
-- fire the events
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'a'));
select pg_sleep(1);
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'a'));
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'b'));
select pg_sleep(1);
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'b'));
select pg_sleep(7);
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'a'));
select pg_sleep(1);
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'a'));
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = '0'));
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'c'));
select pg_sleep(1);
insert into event(event_time,event_type_id) values (now(),(select event_type_id from event_type where event_name = 'a'));
-- query the summary table
select extract (seconds from s.sum_from), extract (seconds from s.sum_to), t.event_name from event_summary s inner join event_type t on (t.event_type_id = s.event_type_id);
关于SQL:索引/分组具有双重清除条件的事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22715297/
我有一个网站,我正在通过学校参加比赛,但我在清除 float 元素方面遇到了问题。 该网站托管在 http://www.serbinprinting.com/corey/development/
我有一个清除按钮,需要使用 JQuery 函数清除该按钮单击时的 TextBox 值(输入的)。 最佳答案 您只需将单击事件附加到按钮即可将输入元素的值设置为空。 $("#clearButton").
我们已经创建了一个保存到 CoreData 然后同步到 CloudKit 的 iOS 应用程序。在测试中,我们还没有找到一种方法来清除应用程序 iCloud 容器中的数据(用于用户私有(private
这是一个普遍的问题,也是我突然想到并且似乎有道理的问题。我看到很多人使用清除div 并且知道这有时不受欢迎,因为它是额外的标记。我最近开始使用 因为它接缝代表了它的实际用途。 当然都引用了:.clea
我有两个单选按钮。如果我检查第一个单选按钮下面的数据将填充在组合框中。之后我将检查另一个单选按钮,我想清除组合框值。 EmployeeTypes _ET = new EmployeeTypes(
我一直在玩 Canvas ,我正在尝试制作一个可以移动和跳跃的正方形,移动部分已经完成,但是跳跃部分有一个问题:每次跳跃时它都会跳得更快 here's a jsfiddle 这是代码: ///////
我该如何在 Dart 上做到这一点? 抓取tbody元素后,我想在其上调用empty(),但这似乎不存在: var el = query('#search_results_tbody'); el.em
我需要创建一个二维模拟,但是在设置新的“框架”时,旧的“框架”不会被清除。 我希望一些圆圈在竞技场中移动,并且每个循环都应删除旧圆圈并生成新圆圈。一切正常,但旧的没有被清除并且仍然可见,这就是我需要改
无论我使用set statusline将状态行更改为什么,我的状态行都不会改变。看起来像 ".vimrc" 39L, 578C
在 WPF 应用程序中,我有一个 ListView 绑定(bind)到我的 ViewModel 上的一个 ObservableCollection。 在应用程序运行期间,我需要删除并重新加载集合中的所
我有一个大型程序,一个带有图形的文本扭曲游戏。在我的代码中的某处,我使用 kbhit() 我执行此代码来清除我的输入缓冲区: while ((c = getchar()) != '\n' && c !
我正在将所有网站的页面加载到主索引页面中,并通过将 href 分成段并在主域名后使用 .hash 函数添加段来更新 URL 显示,如下所示: $('a').click(function(event)
我有一个带有 的表单和 2 控件来保存和重置表单。我正在触发 使用 javascript __doPostBack()函数并在其中传递一个值 __EVENTARGUMENT如果面板应该重置。 我的代
我目前有一堆 UIViewController,每个都是在前一个之上呈现的模式 ViewController。我的问题是我不需要一堆 UIViewController,我只需要最后一个。因此,当出现新
我在一个类中有一些属性方法,我想在某个时候清除这个属性的缓存。 示例: class Test(): def __init__(self): pass @property
在此Test Link我试图将标题和主站点导航安装到博客脚本的顶部。 我清除:两者;在主要网站脚本上工作,但现在把所有东西都扔到了一边。尝试了无数次 fixex 都没有成功!提前感谢 Ant 指点解决
我似乎无法正确清除布局。看this 我无法阻止左栏中的元素向下推右栏中的元素。谁能帮忙? Screenshot with some pointy arrows (死链接) 最佳答案 问题标记/样式似
我希望能够在某个类 (sprite-empos) 之后清除 '' 中的内容,想知道是否有不添加任何新类或不使用 js 的方法(我在下面尝试过不工作)? 为了明确它是“985”,我想在某个视口(view
我想清除ptr_array boost::ptr_array a; ... a.clear(); // missing 如何清理 ptr 容器? 最佳答案 它应该表现得像一个数组,您不能在 C++
这是我使用多 map 制作的一个简单的事件系统;当我使用 CEvents::Add(..) 方法时,它应该插入并进入多重映射。问题是,当我触发这些事件时, multimap 似乎是空的。我确定我没有调
我是一名优秀的程序员,十分优秀!