【发布时间】:2016-08-02 08:19:27
【问题描述】:
我正在尝试在 MS Access 中创建传递查询。该查询通过 ODBC 连接到 Oracle DB。
我的查询在 SQL Developer 中运行良好,但它包含 CASE (...) END 构造。
正如我发现here 有一个Oracle ODBC 驱动程序的问题end 解释这个词。我得到一个错误。
有没有办法解决这个问题?
我的查询:
SELECT
CASE
WHEN PHORGEN.NR_wniosku LIKE 'PHR%'
THEN 'text1'
WHEN PHORGEN.NR_wniosku LIKE 'PBR%'
THEN 'text2'
ELSE 'text3'
END field1,
CASE
WHEN PHORGEN.NR_wniosku IS NULL
THEN reklcomp.solution_date
ELSE
CASE
WHEN phorsol.OPIS_ROZWIAZANIA = '3'
THEN rekldet.SOLUTION_SENDING_DATE
ELSE NVL(
(SELECT MIN(DATA_KSIEGOWANIA)
FROM phorbook
WHERE POWOD_KSIEGOWANIA = '1'
AND Nr_Wniosku = PHORGEN.Nr_Wniosku
),rekldet.SOLUTION_SENDING_DATE)
END
END field2
FROM rgen
JOIN reklcomp
ON rgen.UIDINSTANCEID = reklcomp.UIDINSTANCEID
JOIN rekldet
ON rgen.UIDINSTANCEID = rekldet.UIDINSTANCEID
JOIN reklclient
ON rgen.UIDINSTANCEID = reklclient.UIDINSTANCEID
LEFT JOIN phorgen
ON RGEN.NR_WNIOSKU = PHORGEN.NUMER_OAR
LEFT JOIN phorsol
ON PHORGEN.UIDINSTANCEID = phorsol.UIDINSTANCEID
【问题讨论】:
-
向我们展示查询,我们可以帮助以其他方式编写它,而不使用
caseend -
我已经编辑了问题并添加了查询。
-
答案有帮助吗?
-
是的,这很有帮助,但我找到了另一个更简单的解决方案,请检查我添加的答案。
-
是的,我看到了。看起来很棒!