sql - 我可以在 pl/sql 中使用查询本身作为过滤器吗?

标签 sql oracle plsql dynamic-sql

我知道我在问题标题中没有说清楚。让我解释一下。

假设我有一个表 SOURCE_TABLE,其中有 1 列,如下所示:

Filter 
------------------|
Name='John' 
Surname = 'Smith' 
Age = '25'

我想使用这个表作为过滤器。如下所示:

SELECT * FROM TARGET_TABLE WHERE (SELECT FILTER FROM SOURCE_TABLE)

我听说评估函数可能可以帮助我,但说实话我不明白如何做。

你知道我可以像上面那样使用列作为过滤器源的任何方法吗?


编辑1:

DECLARE 
    my_filter VARCHAR2(100); 
    my_query VARCHAR2(500); 
BEGIN 
    my_query := 'SELECT FILTER FROM SOURCE_TABLE WHERE ROWNUM=1'; 
    EXECUTE IMMEDIATE my_query INTO my_filter; 
    EXECUTE IMMEDIATE 'SELECT * FROM TARGET_TABLE WHERE '|| my_filter; 
END; 

@Sujitmohanty30我在学习EXECUTE IMMEDIATE后想出了上述内容。但我偶然发现了一个问题。对于最终结果来说,这需要是动态的,我想在最后看到选择查询的结果。

最佳答案

假设我们有这两个表:

create table TARGET_TABLE(name varchar2(30), surname varchar2(30));
insert into TARGET_TABLE(name,surname) values ('John', 'Doe');
insert into TARGET_TABLE(name,surname) values ('Ann', 'Smith');
insert into TARGET_TABLE(name,surname) values ('Steven', 'Feuerstein');
insert into TARGET_TABLE(name,surname) values ('Steven', 'King');
commit;

create table SOURCE_TABLE(filter) as
select q'[name='John']' from dual union all
select q'[name='Ann']' from dual union all
select q'[name='Steven' and surname='King']' from dual union all
select q'[surname='Feuerstein']' from dual;

然后您可以使用 xmltable 和 dbms_xmlgen.getXMLtype 动态获取此类行:

https://dbfiddle.uk/?rdbms=oracle_18&fiddle=72abdf18b149cf30882cb4e1736c9c33

select *
from SOURCE_TABLE
    , xmltable(
        '/ROWSET/ROW'
        passing dbms_xmlgen.getXMLtype('select * from TARGET_TABLE where '|| SOURCE_TABLE.filter)
        columns 
          name    varchar2(30) path 'NAME',
          surname varchar2(30) path 'SURNAME'
        ) x;

结果:

FILTER                           NAME                           SURNAME
-------------------------------- ------------------------------ ------------------------------
name='John'                      John                           Doe
name='Ann'                       Ann                            Smith
name='Steven' and surname='King' Steven                         King
surname='Feuerstein'             Steven                         Feuerstein

关于sql - 我可以在 pl/sql 中使用查询本身作为过滤器吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63950437/

相关文章:

c# - Linq to SQL 一对多关系

java - statement.execute() 在 PL/SQL 末尾返回带有斜杠的错误

sql - 将 CSV 文件导入 MySQL 数据库的工具?

java - 无法将 clob 转换为字符串

sql - Oracle SOA 查询需要通配符

oracle - 如何初始化 {TABLE}%ROWTYPE 的可变数组表?

sql - AUTONOMOUS_TRANSACTION

sql - 在 where 子句中使用计算字段

sql - 在 Oracle 中对字母数字数据进行排序

sql - 为什么我收到 ORA-01401 : inserted value too large for column - when I'm not inserting?