Oracle视图:如何获取列定义

时间:2018-05-18 16:38:36

标签: oracle view definition

我有一个Oracle视图:

create view schemaName.viewName as
select case when 1=1 then 1 else 2 end as col1, decode('A','A','B','C') as col2 from dual

是否有办法获取包含此信息的输出或表格:

Column_Name: Col1
Column_Definition: case when 1=1 then 1 else 2 end

Column_Name: Col2
Column_Definition: decode('A','A','B','C')

非常感谢

2 个答案:

答案 0 :(得分:0)

Here is the below anonymous block to get column name and column definition for above view.

      DECLARE

      a varchar2(1000);
      b varchar2(1000);
      c varchar2(1000);

      BEGIN

      EXECUTE  IMMEDIATE 'SELECT TEXT FROM user_views
      WHERE VIEW_NAME=''TEST_VW'' ' INTO a;

      SELECT  regexp_replace(regexp_substr(a, '^[^,]*'),'select|as\W','') -- getting first argument case to get "case when 1=1 then 1 else 2 end col1"

      into b from dual;

      DBMS_OUTPUT.PUT_LINE( 'Column_Name: '|| regexp_substr(b,'[^ ]+$')); -- this command to get last col1 from "case when 1=1 then 1 else 2 end col1"

      DBMS_OUTPUT.PUT_LINE('Column_Definition: '|| regexp_replace(b,'[^ ]+$','')); -- this command to make col1 to empty to get column definition

      select  regexp_replace(substr(a,length(regexp_substr(a, '^[^,]*'))+2),'select|dual|from|as\W','') into c from dual; -- this command to get 2nd column "decode('A','A','B','C') col2"


      DBMS_OUTPUT.PUT_LINE( 'Column_Name: '||  REGEXP_SUBSTR ( c , '[^ ]+' , 1 , 2 )); -- This command will get 2nd column col2 from "decode('A','A','B','C') col2"

      DBMS_OUTPUT.PUT_LINE( 'Column_Definition: '||  REGEXP_SUBSTR ( c , '[^ ]+' , 1 , 1 ));  -- This command will get 1st column decode('A','A','B','C') from "decode('A','A','B','C') col2"

      END;

答案 1 :(得分:0)

Thanks for clarifying ... just try below block and see if this helps ..Also let me know for any column definition which is incorrect

prerequiste for ananymous block:

create view TEST_VW as
select case when 1=1 then 1 else 2 end as col1, decode('A','A','B','C') as col2, 
null as col3 , sysdate as col4 , 'var1' as col5  
from dual;

- 在视图定义中,我希望每列的格式和每列的分隔符是分隔该块的列名和定义的关键。

 create sequence seq
      start with 1;

create table col_nm_def 
      (column_nm varchar2(1000),
      column_def varchar2(1000),
      id number);


Ananymous block;

DECLARE 

      a varchar2(1000); 
      b varchar2(1000); 
      c varchar2(1000);
      d number;

      BEGIN 

      EXECUTE  IMMEDIATE 'SELECT TEXT FROM user_views 
      WHERE VIEW_NAME=''TEST_VW'' ' INTO a;

       EXECUTE  IMMEDIATE 'delete from col_nm_def';

       EXECUTE  IMMEDIATE  'drop sequence seq';


       EXECUTE  IMMEDIATE     'create sequence seq
      start with 1';


      select regexp_replace(regexp_replace(a,'select|from|dual',''),'as\W|, ' , '|') into b from dual; -- replacing as and (, ) to | symbol (try to change symbol if view uses this pipe in transformation)

      select regexp_count(b,'[|]') into d from dual; 

      d:=d+1;

      For i in 1..d

      LOOP

      insert into col_nm_def  values (REGEXP_SUBSTR ( b , '[^|]+' , i+1 , i+1 ),REGEXP_SUBSTR ( b , '[^|]+' , i , i ),seq.nextval);
      COMMIT;

    END LOOP;
    END;


Final result : select only odd rows 

select * from col_nm_def where mod(id,2)=1 order by ID;