- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
以下是一个不太适合 RDBMS 的问题,我认为,但这就是我要处理的问题。
我正在尝试编写一个工具来搜索存储在数据库中的日志。有些行可能是:
Time | ID | Object | Description
2012-01-01 13:37 | 1 | 1 | Something happened
2012-01-01 13:39 | 2 | 2 | Something else happened
2012-01-01 13:50 | 3 | 2 | Bad
2012-01-01 14:08 | 4 | 1 | Good
2012-01-01 14:27 | 5 | 1 | Bad
2012-01-01 14:30 | 6 | 2 | Good
对象是一个外键。实际上,时间会随着 ID 的增加而增加,但这并不是一个实际的约束。实际上还有更多的领域。这是一个 Postgres 数据库 - 我也希望能够支持 SQLite,但我知道这很可能是不可能的。
现在,我希望能够对对象 2 发生的所有不良事件运行查询:
SELECT * FROM table WHERE Object = 2 AND Description = 'Bad';
但是查看结果周围的一些上下文行通常很有用 - 正如 grep
的 -C
选项在搜索文本日志时非常有用.对于上面的查询,如果我们想要在任一侧有一行上下文,除了第 3 行之外,我们还需要第 2 行和第 6 行。
如果原始查询返回多行,则需要检索更多上下文。请注意,上下文不是从与对象 1 关联的事件中检索的;我们只消除了对描述的限制。此外,所涉及的顺序以及由此决定什么与什么相邻的顺序是由时间场引起的。
这指定了我想要实现的目标,但相关的数据库相当大,至少与它运行的机器的能力相比是这样。
最常被引用的获取相邻行的解决方案要求您为每个结果运行一个额外的查询,我称之为基本查询;这不好,因为那可能有数千个查询。
我目前最不坏的解决方案是运行查询以检索可能是上下文的所有可能行的 ID - 在上面的示例中,这将是搜索与对象 2 相关的所有行。然后我得到匹配的 ID基本查询,扩展(使用所有可能 ID 的列表)到与基本查询或上下文匹配的行的 ID 列表,然后最终检索这些 ID 的数据。这有效,但不优雅且缓慢。从远程计算机使用该工具时速度特别慢,因为初始 ID 列表可能非常大,检索它然后仅通过 Internet 传输它可能是无节制的。
我尝试过的另一种解决方案是使用子查询或 View 来计算行的“缓冲区序列”。添加了该字段后的表格如下所示:
Time | ID | Sequence | Object | Description
2012-01-01 13:37 | 1 | 1 | 1 | Something happened
2012-01-01 13:39 | 2 | 1 | 2 | Something else happened
2012-01-01 13:50 | 3 | 2 | 2 | Bad
2012-01-01 14:08 | 4 | 2 | 1 | Good
2012-01-01 14:27 | 5 | 3 | 1 | Bad
2012-01-01 14:30 | 6 | 3 | 2 | Good
在此表上运行基本查询然后允许您通过添加或减去 Sequence 值来生成所需的 ID 列表。这消除了通过线路传输行负载的问题,但现在数据库必须运行这个复杂的子查询,而且速度慢得令人无法接受,尤其是在第一次运行时——给定用例,查询是零星的,缓存不是很有效.
如果我负责模式,我可能只是将这个字段存储在数据库中,但我不是,所以欢迎提出任何改进建议。谢谢!
最佳答案
您应该使用ROW_NUMBER
窗口函数
http://www.postgresql.org/docs/current/static/functions-window.html
邻接是一种抽象构造并依赖于显式排序(或 PARTITION OVER
)...您是指具有前面时间戳的排序吗?
决定你如何决定你想要什么样的“相邻”,然后得到 ROW_NUMBER
超过那个标准。
一旦您拥有了,您只需JOIN
具有ROW_NUMBER
+/- 1 的项目的每一行
关于sql - 在 SQL 查询中选择相邻行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24212453/
我想在数组中找到连接(相邻)的元素。 例如,在数组中: [1,2,3,4,5] 要访问所有 2 个连通元素,输出将为: 1,2 2,3 3,4 4,5 要访问所有 3 个连通元素,输出将为 1,2,3
我有三个 Sprite ,彼此堆叠在一起。 我修改了他们的 transform.matrix 以给出他们一致增长的外观。 但是,根据比例因子,瓷砖之间有时会出现小裂缝。 cracks between
我正在阅读有关 Margin Collapsing 的文章,我遇到了这个:margin Adjacent siblings The margins of adjacent siblings are c
float div 的框阴影被其右侧的邻居截断,但左侧未截断。 我玩过 z-index 和 overflow: visible,但没有用。 HTML: CSS: .doc-page {
我有多个元素说卡片。这些卡片需要水平堆叠并且高度需要相同。这正在发生在我身上。 每张卡片都有图像、文本和按钮。每张卡片的图像和文本应采用任何卡片中的最大高度,以便它们正确对齐。这不会发生在我身上。 如
我有这个 GUI 我使用了 GridBagLayout,但我不知道为什么 Plain Bread 复选框与其相应的标签之间有很大的间距。 而且,我尝试仅增加按钮沿 x 轴的间距,但尽管重置了插图,但沿
在过去,我已经为自定义元素符号使用了数百次列表项背景图像,但不知何故从未遇到过这个问题。 基本上,我有一个 IMG float 在无序列表的左侧。元素符号背景图像设置在每个 LI 的左上角。但是, f
我正在使用 Bootstrap 框架并使用 2 列网格。 html 内容有标题、链接、副标题和文本。这增加了该列的高度。我希望它旁边的列与其高度匹配(以便图像显示)没有设置高度图像不显
我有一个 php 代码可以生成数百个 和 标签。我的问题如下,我有以下内容: X X 我想要第二个的边框颜色更重要,以便共享边框显示为灰色而不是黑色。我可以在第二个 td 中使用重要性或继承标签吗?
Place holder for Radio1 Place holder for Radio2 在此,我只想要 与相应的单选按钮相关联是可见的,但是...... * { visibilit
我正在尝试在 html 中实现以下布局。更大的 div 1。然后是它旁边的另一个 div,顶部有一个边距。如果我给 float: left 给第一个 div,给第二个 div margin-top 也
假设我有 2 个名为 IN 和 MASK 的二进制输入。实际字段大小可能是 32 到 256 位,具体取决于用于完成任务的指令集。两个输入都会改变每次调用。 Inputs: IN = ...110
我想知道是否有一种简洁/一行的方法来执行以下操作: pack :: [a] -> [(a, a)] pack [] = [] pack [_] = [] pack (x:y:xs
下面的代码分为两部分,一部分处理头部的管理,另一部分处理“主体”,当我执行代码时引发下面的异常,我该如何解决该错误?我不知道下面的错误是什么原因造成的,错误是在react的解析上 错误: Line
http://imgur.com/a/DA5i4 在上面的两张图片中你可以看到我有一个主容器,里面装满了 3 个较小的 div,一个大的在中间,两个瘦的在两边,但是右边直到中间的 div 下面才开始。
正如我在标题中解释的所有内容,然后我将只为你们提供我现在拥有的代码,我一直在努力实现我想要的东西很长时间但没有运气......它表现得像响应式的,但即使调整大小我也想将其保持在原位...截图
我编写了一个 jquery 插件,它使用 Flot 将 HTML 表格转换为图表。 HTML 是从 XSLT 生成的,在 XSLT 中我有以下代码来调用我的插件。此代码尝试在 blah1 和 blah
我正在尝试实现这样的布局。 aaa xxxxxx oooo aaa xxxxxx oooo xxxxxx xxxxxx bbb xxxxxx cccc bbb xxxxxx cc
在包含网格的 2 个 div 上使用内联 css 显示不起作用 最佳答案 为您的 div 指定宽度并根据您的要求使用“float: left”或“right”。不要对 div 使用“内联” 例如 CS
我将 MVC 项目中的一些代码返回到网页。我无法用撇号解决问题,当我的电话看起来像这样时,我如何忽略它 document.getElementById('some').insertAdjacentHT
我是一名优秀的程序员,十分优秀!