gpt4 book ai didi

sql - Oracle SQL - UNION 在 "table does not exist"时中断

转载 作者:行者123 更新时间:2023-12-04 14:35:36 26 4
gpt4 key购买 nike

我是 Oracle SQL 的新手(并且通常没有 SQL 经验)。如果我能得到一些帮助解决我的问题,我将不胜感激。

我需要查询多个表和 View (大约 30 个)并将其作为 UNION 跨所有查询并返回单个结果集。但是,某些表可能存在也可能不存在。我知道要查询的所有 30 个表/ View 的确切名称。在执行大型 UNION 之前,我可能会执行其他查询,但最终,我必须返回所有行的单个结果。我无法在我的 sql 脚本中“定义”变量。

这些是我无法控制的限制。为了使用现有的工作流程,我必须在这些限制范围内操作。

问题是,如果任何表/ View 不存在,那么整个 UNION 都会失败,我根本得不到任何结果。我在第一次缺少 View /表时得到这个:

SQL Error: ORA-00942: table or view does not exist
00942. 00000 - "table or view does not exist"
*Cause:
*Action:

我希望能够在不中断的情况下处理这个问题。我想简单地跳过丢失的表并返回剩余的行(尽管我知道这是在不知道表是否存在的情况下尝试查询的糟糕设计)。如果我最终包含错误消息也没关系,因为解析器最终会跳过这些消息。

我有这样的东西。如果任何 View 不存在,一切都会失败,我不会得到任何结果:

select col1 || col2 || ... from view1
union
select col1|| col2 || ... from view2
union
select name from view3
.
.
select ... from view30;

如果有帮助,我可以切换到 PL/SQL。我对 PL/SQL 没有太多经验,但如果它能解决问题,我可以使用它。我阅读了一些有关 PL/SQL 的资料,但无法想出一些直接的方法来执行此操作。

非常感谢任何帮助。让我知道是否可以提供任何其他详细信息。

谢谢。

最佳答案

同事们不会说你不能那样做 - 他们说你不应该这样做,这是根本问题的原因。但世界并不完美——它经常给你一把锯子,让你去敲钉子。您的问题有一个解决方案 - 它涉及动态 SQL 和一些自定义 PL/SQL 代码。简化的解决方案:

创建一个包和一个函数:

function does_tbl_exists(p_tbl_name in varchar2) return number is

l_stmt varchar2(60);

begin

l_stmt := 'select count(*) from ' ||p_tbl_name;
execute immediate l_stmt;
return 1;
exception
when others then
return 0 ;
end;

用一些数据创建了一个测试表 TEST_TBL。然后我们在 pl/sql block 中构建我们的 SQL 语句:

declare

l_count number;
l_stmt varchar2(400);
l_tab_name_1 varchar2(30) := 'TEST_TBL';
l_tab_name_2 varchar2(30) := 'TEST_TBL2';

begin

if test_pck.does_tbl_exists(p_tbl_name => l_tab_name_1) = 1 then
l_stmt := 'select count(*) count_number from ' || l_tab_name_1;
end if;

if test_pck.does_tbl_exists(p_tbl_name => l_tab_name_2) = 1 then

if l_stmt is not null then
l_stmt := l_stmt || ' union all' || chr(10);
end if;

l_stmt := l_stmt || 'select count(*) count_number from ' || l_tab_name_2;

end if;

if l_stmt is not null then

l_stmt := 'select sum(tmp.count_number) from (' || l_stmt || ') tmp';

dbms_output.put_line(l_stmt);
execute immediate l_stmt into l_count;
dbms_output.put_line('count: '||l_count);


else

dbms_output.put_line('Nothing todo.');

end if;

end;

通过这个模板,您可以构建您最终的 SQL 语句。但将此作为最后的手段 - 我认为你仍然应该去找上级并与他们交谈,他们目前的“要求”是“糟糕的”并且他们应该感到“糟糕”(在此处插入模因)。

关于sql - Oracle SQL - UNION 在 "table does not exist"时中断,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51920589/

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