gpt4 book ai didi

sql - 将嵌套解码转换为等效的 CASE 语句(从 Oracle 转换到 PostgreSQL 需要)

转载 作者:行者123 更新时间:2023-11-29 14:15:02 28 4
gpt4 key购买 nike

我在 Oracle 11.2.0.4 上。我有一个嵌套的 DECODE 语句,我需要将其转换为 CASE 语句。有人可以帮忙吗?我不确定它是如何完成的,事实上我并不完全理解它的逻辑。如果有人可以解释它基本上打算做什么以及使用对我非常有用的 CASE 重写的函数是什么。这是功能...(注意:不要担心表连接,有 3 个表和一个条件等。请关注 DECODE 及其到 CASE 的转换)。我也必须手动转换,工具不是一个选项。

CREATE OR REPLACE FUNCTION TMP_Func
RETURN NUMBER
IS
V NUMBER;
BEGIN
SELECT DECODE (
NVL (tab1.flag1, '~'),
'D', DECODE (tab1.code_oid, NVL (tab3.bu_id, '-'), 1, 0),
'C', DECODE (tab1.code_oid, NVL (tab3.cost_id, '-'), 1, 0),
DECODE (tab2.oid,
DECODE (tab1.co_id, NULL, tab2.oid, tab1.co_id), 1,
0))
INTO V
FROM tab1, tab2, tab3
WHERE tab2.OID = tab1.sec_id;

RETURN V;
END;

最佳答案

像这样:

select CASE WHEN COALESCE(tab1.flag1,'~') = 'D' THEN 
CASE WHEN tab1.code_oid=COALESCE(tab3.bu_id, '-') THEN 1 else 0 end

WHEN COALESCE(tab1.flag1,'~')='C' THEN
CASE WHEN tab1.code_oid=COALESCE(tab3.cost_id, '-') THEN 1 else 0 end

else
CASE WHEN tab2.oid=COALESCE(tab1.co_id,tab2.oid) THEN 1 else 0 end
end
FROM tab1, tab2, tab3
WHERE tab2.OID = tab1.sec_id;

NVL 被 COALESCE 取代

DECODE(a,b,c,d,e,...,f) 替换为:

  CASE WHEN a=b THEN c
WHEN a=d THEN e
...
else f
end

你最后一次解码 ( DECODE (tab1.co_id, NULL, tab2.oid, tab1.co_id), 1, 0))) 实际上是一个 NVL( tab1.co_id,tab2.oid)

关于sql - 将嵌套解码转换为等效的 CASE 语句(从 Oracle 转换到 PostgreSQL 需要),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52165727/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com