- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
这是我当前的 oracle 语句:
WITH table_ AS (
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, CASE BITAND(RAWOUTPUT1, POWER(2,0))
WHEN 0 THEN 'FALSE'
ELSE 'TRUE'
END AS Pumpe1_1
FROM pump_box_hist
)
, table2_ AS (
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, Pumpe1_1
, LEAD (Pumpe1_1) OVER (ORDER BY datetime) as next_
, LAG (Pumpe1_1) OVER (ORDER BY datetime) as priv_
FROM table_
)
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, Pumpe1_1
FROM table2_
WHERE (
Pumpe1_1 = next_
AND Pumpe1_1 <> priv_
AND DATETIME > to_date('30.10.2014 00:00:00', 'DD-MM-YYYY HH24:MI:SS')
AND DATETIME < to_date('02.11.2014 00:00:00', 'DD-MM-YYYY HH24:MI:SS')
)
;
它工作正常,但需要将近 50 秒才能执行。因为数据按 DATETIME
排序,所以如果 DATETIME
大于给定值,则执行 while 循环
退出。在这个循环中,我将对小于给定的日期使用 IF
。我尝试了一段时间,但没有成功。
我试过的代码:
WHILE (SELECT DATETIME FROM pump_box_hist) < to_date('02.11.2014 00:00:00', 'DD-MM-YYYY HH24:MI:SS')
LOOP
IF DATETIME > to_date('30.10.2014 00:00:00', 'DD-MM-YYYY HH24:MI:SS') THEN
WITH table_ AS (
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, CASE BITAND(RAWOUTPUT1, POWER(2,0))
WHEN 0 THEN 'FALSE'
ELSE 'TRUE'
END AS Pumpe1_1
FROM pump_box_hist
)
, table2_ AS (
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, Pumpe1_1
, LEAD (Pumpe1_1) OVER (ORDER BY datetime) as next_
, LAG (Pumpe1_1) OVER (ORDER BY datetime) as priv_
FROM table_
)
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, Pumpe1_1
FROM table2_
WHERE (
Pumpe1_1 = next_
AND Pumpe1_1 <> priv_
)
;
END IF;
END LOOP;
Error: unknown command in line 32 and 33 (Editor's note: these have been lines 11 and 12 in the original formatting containing
END IF;
andEND LOOP;
)
那么我怎样才能让 LOOP
和 IF
工作呢?谢谢
最佳答案
您从客户端收到“未知命令”错误,因为您试图在纯 SQL 中使用 PL/SQL 控制语句; while
、if
、end if
和 end loop
在 SQL 中无效。
您真正要做的似乎只是移动过滤器,这样它们就可以进入您的第一个 CTE:
WITH table_ AS (
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, CASE BITAND(RAWOUTPUT1, POWER(2,0))
WHEN 0 THEN 'FALSE'
ELSE 'TRUE'
END AS Pumpe1_1
FROM pump_box_hist
WHERE DATETIME > to_date('30.10.2014 00:00:00', 'DD-MM-YYYY HH24:MI:SS')
AND DATETIME < to_date('02.11.2014 00:00:00', 'DD-MM-YYYY HH24:MI:SS')
)
, table2_ AS (
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, Pumpe1_1
, LEAD (Pumpe1_1) OVER (ORDER BY datetime) as next_
, LAG (Pumpe1_1) OVER (ORDER BY datetime) as priv_
FROM table_
)
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, Pumpe1_1
FROM table2_
WHERE (
Pumpe1_1 = next_
AND Pumpe1_1 <> priv_
)
;
但这现在意味着 table_
中的第一行和最后一行将没有更早/更晚的行供滞后/领先查找,所以 priv_
/ next_
(分别)对于那些可能会影响您的最终结果的人来说将为空。不过,您可以在最后的 where
子句中显式检查空值:
...
FROM table2_
WHERE (
(Pumpe1_1 = next_ or next_ is null)
AND (Pumpe1_1 <> priv_ or priv_ is null)
)
您也可以通过对原始值而不是计算标志进行超前/滞后来使用单个 CTE 来执行此操作,这不会有很大不同,但会更短一些;尽管为了清楚起见,您可能更喜欢两个 CTE:
WITH table_ AS (
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, CASE BITAND(RAWOUTPUT1, POWER(2,0))
WHEN 0 THEN 'FALSE'
ELSE 'TRUE'
END AS Pumpe1_1
, CASE BITAND(LAG(RAWOUTPUT1) OVER (ORDER BY datetime), POWER(2,0))
WHEN 0 THEN 'FALSE'
ELSE 'TRUE'
END AS priv_
, CASE BITAND(LEAD(RAWOUTPUT1) OVER (ORDER BY datetime), POWER(2,0))
WHEN 0 THEN 'FALSE'
ELSE 'TRUE'
END AS next_
FROM pump_box_hist
WHERE DATETIME > to_date('30.10.2014 00:00:00', 'DD.MM.YYYY HH24:MI:SS')
AND DATETIME < to_date('02.11.2014 00:00:00', 'DD.MM.YYYY HH24:MI:SS')
)
SELECT DATETIME
, TOTALTIME1
, RAWOUTPUT1
, Pumpe1_1
FROM table_
WHERE (
(Pumpe1_1 = next_ or next_ is null)
AND (Pumpe1_1 <> priv_ or priv_ is null)
)
;
关于database - 甲骨文 while 循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28760546/
我正在尝试在 64 位 Windows 7 计算机上安装 Oracle Instant Client 和 ODBC 驱动程序。 我已经下载了两个 即时客户端包 - 基本 即时客户端包 - ODBC 我
每当我在 ORACLE 中授予用户“所有权限”(下面的示例)时,这实际上做了什么? 我的理解是,它赋予用户任何权限,例如在该架构中插入、删除等,但不数据库中的任何架构? grant all privi
我目前无法访问任何 Oracle 书籍,而且我的在线搜索几乎没有返回任何结果(Google 中的 (+) 什么也没有显示)。我正在查看现有代码以向查询添加一些字段并看到: AND lookup.Loo
我的访问表如下: insert into Visit values(12, to_date('19-JUN-13', 'dd-mon-yy'), to_date('19-JUN-13 12:00 A.
我的数据格式如下: cons_Type COLUMN_NAME P (COL1) R (COL6_REFERENCE) R (C
我希望我的表根据它的 TEMPLATE_ID 对其“排序依据”列进行排序。 我希望这发生在插入时(可能通过插入触发器)。 例如,如果我运行以下插入,我应该得到下表中的值。 INSERT INTO TE
我有一个场景,我必须为低于 SQL 阈值限制的值排名负数。任何人都可以帮助我吗? Name Target Rank John 2500 -2 Hopkins 4000 -1
我想用另一个表中的随机名称更新表中的名称。表 Users 中有真实的用户名。表 tmp_users 中有编造的名字。我想用 tmp_users 表中的随机名称更新用户表中的所有名称。这个想法是用假客户
如何从匹配删除表的表中删除记录?就像,我有一个记录键表,上面写着需要从我的主表中删除的内容。我将如何编写删除语句来表示“从我的主表中删除此字段与我的删除表中的字段匹配的任何内容?” 最佳答案 如果是小
我有一个关于表创建的问题。我想将“Ono”和“Pno”的属性组合成一个新表的主键。这些都是外键,每个都来自不同的表。我是否只使用 CONSTRAINT Ono_Pno_PK PRIMARY KEY (
我的情况(简化)如下所示: 表 UNITS 在 UNITS.NAME 上有一个 PK。 (单位名称, varchar(12)) 表 DEPTS 在 DEPTS.NAME 上有一个 PK。 (部门名称,
假设我有一个带有自动递增代理键的表。 这是使用反向索引的好例子吗? 我说的对吗: 插入(到索引中)会更快......因为新值会随机插入,而不是总是进入最右边的叶子(不断强制重新平衡)。 索引查找会稍微
我试图创建一个新表 (tableB),它带有到另一个表 (tableA) 的外键约束,只是想知道是否可以创建所有需要的约束和索引。我的目标是拥有一个 create table不需要 alter tab
唯一约束列中是否可以有2个或多个空值? 最佳答案 易于检查:(答案为是) create table t1 (col1 number unique); Table T1 created. insert
如何从delphi 7(ado组件)将blob数据插入oracle xe 最佳答案 使用TAdoQuery检查这些样本组件。 直接从文件加载数据 ADOQuery1.Parameters.AddPa
我试图在表 A 上创建一个约束,以检查表 B 中是否存在一组记录。我可以使用外键,但问题是表 B 中的数据不唯一。 有没有办法在不创建触发器的情况下创建这样的约束? 编辑:我无法更改表 B 结构。 最
我正在加载一个查找员工表的表。然而,有时源文件和 Employee 表中的名称不正确匹配。 **Employee table:** Employee Name Paul Jaymes **Source
我正在寻找在相对较大的表中进行相对复杂查询的最有效方法。 概念是: 我有一个表,其中包含可以相互并行运行的阶段的记录 记录量超过 500 万(并且还在增加) 时间段从大约 5 年前开始 由于性能原因,
我已经搜索了我的问题的解决方案,这个 question describes it perfectly . Let´s say I have one table called ProjectTimeSp
如何获取 varchar2 列中允许的最大和最小长度。我必须测试来自某个远程数据库的临时表的传入数据。并且要针对特定列测试每一行值是否具有可以设置到该列中的最大值或最小值。 所以我要使用其架构详细
我是一名优秀的程序员,十分优秀!