- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
假设我的 Oracle 数据库中有一个非常大的表,其中填充了数千个项目的数据。此数据会在一天中非常频繁地更新,并且每次更新都有一个时间戳。
因此,例如,表格如下所示(我知道列名不好,这只是示例):
每日待定:
Date: ItemNo: CharA: .... CharN: Time_Stamp:
2014/02/15 123 .... 2014/02/15 10:00AM
2014/02/15 123 .... 2014/02/15 11:00AM
2014/02/15 123 .... 2014/02/15 02:13PM
2014/02/15 234 .... 2014/02/20 01:00PM
2014/02/15 234 .... 2014/02/20 09:00PM
...
2014/02/16 123 .... 2014/02/20 08:15PM
...
然后,我有一个包含相同项目编号的表,用于存储其他信息,但它在整个月内保持不变,因此它看起来如下:
TBLMonthly:
Date: ItemNo: CharA: .... CharK:
2014/01/31 123 ....
2014/01/31 234 ....
2013/12/31 123 ....
2013/12/31 234 ....
...
现在,我需要为每个零件号和每个日期获取每日表中可用的最新信息,对于某些特性,如果它们不存在,则从每月表中获取它们。
我的 SQL 查询如下所示:
WITH All_Data AS
(
SELECT
ROW_NUMBER() OVER(PARTITION BY A.Date, A.ItemNo ORDER BY A.Time_Stamp) AS RN,
A.Date, A.ItemNo,
NVL(A.CharA, B.CharA),
B.CharB,
... whatever other characteristics ...
FROM
TBLDaily A,
TBLMonthly B,
WHERE
A.ItemNo = B.ItemNo
AND
A.Date BETWEEN To_Date('2012-12-31', 'yyyy-MM-dd') AND To_Date('2014-02-24', 'yyyy-MM-dd')
AND
B.Date = (SELECT max(Date) FROM TBLMonthly WHERE Date <= A.Date)
)
SELECT *
FROM All_Data
WHERE RN = 1
ORDER BY Date, ItemNo
现在,这个查询需要非常的时间才能完成(我从昨天下午开始让它运行,今天早上它仍在执行查询)。我知道它适用于一个非常大的数据集,但我查询更大的数据集的速度要快得多。我猜测这是由于:
PARTITION BY
或 B.Date = (SELECT max(Date) FROM TBLMonthly WHERE Date <= A.Date)
但我不确定,更糟糕的是,我不知道如何修复它以使其更有效率并且不会花费这么长时间。
任何想法/帮助将不胜感激!!
最佳答案
使用这种方法也许您的查询会更容易、更快捷:
with t AS
(SELECT DISTINCT LAST_VALUE(CharA) OVER (PARTITION BY Date, ItemNo ORDER BY Time_Stamp) as CharA,
MAX(Time_Stamp) OVER (PARTITION BY Date, ItemNo) as Time_Stamp
FROM TBLDaily)
SELECT *
FROM t
JOIN TBLMonthly m ON m.ItemNo = d.ItemNo and t.Time_Stamp = m.Time_Stamp
关于sql - Oracle - 查询大型数据集需要很长时间 - 有没有办法优化它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22044749/
这个问题在这里已经有了答案: Isn't an Int64 equal to a long in C#? (2 个答案) 关闭 9 年前。 它不应该是一个整数类型吗? 这样,一些使用 int 的函数
当我遇到一些我想知道的事情时,我正忙着解析一个二进制文件。 Stream.Position属性的类型为Int64或long。为什么是这样?因为流中的位置不能为负,所以使用 UInt64 不是更有意义吗
所以第一部分是我从用户那里获得输入,在本例中,输入是“1”作为从另一个函数接收的字符值。 printf ("\nPlease enter 1, 2, 3 or q: "); option =
我正在尝试使用以下代码从 REST 服务返回 JSON: $categories = $categoriesController->listAll(); if($categories){ hea
我阅读了文档,它说 long 是 %li,但打印输出返回为 -2147024891。是什么赋予了? 最佳答案 您甚至没有提供要打印的号码,但我猜您已经无意中发现了签名打印和未签名打印之间的区别。 使用
我正在创建自定义购物车,我正在构建一个查询,该查询从检索我刚刚保存到购物车表中的 session_id 开始。我知道这个值被保存了,我在 mysql 命令行运行这个查询,它返回我需要的但我没有将值放入
我有一个包含 textView 的 scrollView。如果文本很长并且不适合屏幕,我想增加 textView 高度(我想我可以通过添加 NSLayoutConstraint outlet 并修改它
我有一个基本的数据库处理程序类,其中有一个使用 PDO::FETCH_ASSOC 参数返回结果集的公共(public)方法: public function resultSet() { $th
在后台线程中,我调用 PublishSubject.onNext(); 并在主线程中通过 subscribe(PublishSubject.filter(message -> message.getI
我想知道为什么 Amazon Web Services 控制台登录页面有这么长的 url?为什么不只发布数据而不显示其中包含大量数据的冗长 url。以这种方式实现有什么充分的理由吗? 最佳答案 我认为
这个问题在这里已经有了答案: Can I mix MySQL APIs in PHP? (4 个答案) 关闭 6 年前。 希望我犯了一个快速而明显的错误,我浏览了 previous question
我得到了答案:如果我禁用了cookie,那么使用URL重定向我可以传递JSESSIONID,但我的URL已经很长,因为我使用它有约束的GET方法。那怎么办我应该使用我的 session 吗?我希望我的
目前,当我使用 DOMDocument 对象并调用 saveHTML() 时,它会自动添加一些我不需要的 html 标签。我尝试了此处建议的解决方案 ( https://stackoverflow.c
我是一名优秀的程序员,十分优秀!