Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

ओरेकल डेटाबेस से डेटा पुनर्प्राप्त करना और प्रदर्शित करना

आप कॉलम विवरण/नाम - एक नियतात्मक क्रम में - कुछ इस तरह से प्राप्त कर सकते हैं:

select coalesce(ct.col_desc, ct.col_name)
from col_tab ct
left join user_tab_columns utc
on utc.table_name = ct.table_name and utc.column_name = ct.col_name
where ct.table_name = 'TABLE1'
order by utc.column_id, ct.col_name;
COALESCE(CT.COL_
----------------
TABLE 1 COLUMN 3
TABLE 1 COLUMN 1
TAB1_COL_5
TABLE 1 COLUMN 2
TABLE 1 COLUMN 4

उन पंक्तियों को स्तंभों में पिवोट करना गतिशील रूप से करने की आवश्यकता होगी।

आप डेटा को उसी क्रम में उसी क्रम में प्राप्त करने के लिए एक गतिशील क्वेरी भी उत्पन्न कर सकते हैं।

यह दो आउटपुट प्राप्त करने के लिए SQL*Plus (या SQLcl, या SQL डेवलपर) बाइंड वैरिएबल रेफ कर्सर का उपयोग करता है, और ब्लॉक के भीतर परिभाषित तालिका नाम का उपयोग करता है; लेकिन आसानी से एक ऐसी प्रक्रिया के रूप में अनुकूलित किया जा सकता है जो तालिका के नाम से पारित हो और रेफ कर्सर के लिए पैरामीटर हो:

var rc1 refcursor;
var rc2 refcursor;

declare
  l_table_name varchar2(30) := 'TABLE1';
  l_stmt varchar2(4000);
begin
  select 'select '
    || listagg('''' || coalesce(ct.col_desc, ct.col_name) || '''',  ',')
         within group (order by utc.column_id, ct.col_name)
    || ' from dual'
  into l_stmt
  from col_tab ct
  left join user_tab_columns utc
  on utc.table_name = ct.table_name and utc.column_name = ct.col_name
  where ct.table_name = l_table_name;

  dbms_output.put_line(l_stmt);

  open :rc1 for l_stmt;

  select 'select '
    || listagg(coalesce(utc.column_name, 'null') || ' as ' || ct.col_name,  ',')
         within group (order by utc.column_id, ct.col_name)
    || ' from ' || l_table_name
  into l_stmt
  from col_tab ct
  left join user_tab_columns utc
  on utc.table_name = ct.table_name and utc.column_name = ct.col_name
  where ct.table_name = l_table_name;

  dbms_output.put_line(l_stmt);

  open :rc2 for l_stmt;

end;
/

ब्लॉक चलाने से dbms_output मिलता है केवल डिबगिंग के लिए बयानों के, लेकिन रुचि के हो सकते हैं:

select 'TABLE 1 COLUMN 3','TABLE 1 COLUMN 1','TAB1_COL_5','TABLE 1 COLUMN 2','TABLE 1 COLUMN 4' from dual
select TAB1_COL_3 as TAB1_COL_3,TAB1_COL_1 as TAB1_COL_1,TAB1_COL_5 as TAB1_COL_5,TAB1_COL_2 as TAB1_COL_2,null as TAB1_COL_4 from TABLE1

और फिर आप रेफरी कर्सर को प्रिंट कर सकते हैं (फिर से, क्लाइंट-विशिष्ट व्यवहार):

print rc1

'TABLE1COLUMN3'  'TABLE1COLUMN1'  'TAB1_COL_ 'TABLE1COLUMN2'  'TABLE1COLUMN4' 
---------------- ---------------- ---------- ---------------- ----------------
TABLE 1 COLUMN 3 TABLE 1 COLUMN 1 TAB1_COL_5 TABLE 1 COLUMN 2 TABLE 1 COLUMN 4

print rc2

TAB1_COL_3      TAB1_COL_1    TAB1_COL_5     TAB1_COL_2    TAB1_COL_4
--------------- ------------- -------------- ------------- ----------
TAB1_COL3_DATA1 TAB1_COL1_DAT TAB1_COL5_DAT2 TAB1_COL2_DAT           
TAB1_COL3_DATA2 TAB1_COL1_DAT TAB1_COL5_DAT1 TAB1_COL2_DAT           
TAB1_COL3_DATA3 TAB1_COL1_DAT TAB1_COL5_DAT3 TAB1_COL2_DAT           

उस स्थिति में आप ऑर्डरिंग लॉजिक को बढ़ाने के लिए केस एक्सप्रेशन का उपयोग कर सकते हैं:

समूह के भीतर
         within group (order by case ct.col_name 
                                  when 'TAB1_COL_3' then 1
                                  when 'TAB1_COL_1' then 2
                                  else 3 end,
                                utc.column_id, ct.col_name)

जो तब मिलता है:

'TABLE1COLUMN3'  'TABLE1COLUMN1'  'TAB1_COL_ 'TABLE1COLUMN2'  'TABLE1COLUMN4' 
---------------- ---------------- ---------- ---------------- ----------------
TABLE 1 COLUMN 3 TABLE 1 COLUMN 1 TAB1_COL_5 TABLE 1 COLUMN 2 TABLE 1 COLUMN 4


TAB1_COL_3      TAB1_COL_1    TAB1_COL_5     TAB1_COL_2    TAB1_COL_4
--------------- ------------- -------------- ------------- ----------
TAB1_COL3_DATA1 TAB1_COL1_DAT TAB1_COL5_DAT2 TAB1_COL2_DAT           
TAB1_COL3_DATA2 TAB1_COL1_DAT TAB1_COL5_DAT1 TAB1_COL2_DAT           
TAB1_COL3_DATA3 TAB1_COL1_DAT TAB1_COL5_DAT3 TAB1_COL2_DAT           

या संभवतः नाम के बजाय विवरण का उपयोग करना, इस पर निर्भर करता है कि क्या यह नाम या विवरण वही रहता है (उदाहरण से अनुमान लगाना कठिन है)।

अंत में यहां इसकी वास्तव में आवश्यकता नहीं है, और listagg . से अधिक जटिल है मैंने ऊपर इस्तेमाल किया; लेकिन आप कुछ ऐसा कर सकते हैं;

  select '
select * from (
  select row_number()
           over (order by case ct.col_name 
                            when ''TAB1_COL_3'' then 1
                            when ''TAB1_COL_1'' then 2
                            else 3
                          end,
                          utc.column_id, ct.col_name) as pos,
         coalesce(ct.col_desc, ct.col_name) as name
  from col_tab ct
  left join user_tab_columns utc
  on utc.table_name = ct.table_name and utc.column_name = ct.col_name
  where ct.table_name = :tab
)
pivot (max(name) as col for (pos) in ('
|| listagg(level, ',') within group (order by level)
|| '))'
  into l_stmt
  from dual
  connect by level <= (select count(*) from col_tab where table_name = l_table_name);

  dbms_output.put_line(l_stmt);

  open :rc1 for l_stmt using l_table_name;

जो उत्पन्न गतिशील क्वेरी को इस रूप में दिखाते हुए आउटपुट प्राप्त करता है:

select * from (
  select row_number()
           over (order by case ct.col_name 
                            when 'TAB1_COL_3' then 1
                            when 'TAB1_COL_1' then 2
                            else 3
                          end,
                          utc.column_id, ct.col_name) as pos,
         coalesce(ct.col_desc, ct.col_name) as name
  from col_tab ct
  left join user_tab_columns utc
  on utc.table_name = ct.table_name and utc.column_name = ct.col_name
  where ct.table_name = :tab
)
pivot (max(name) as col for (pos) in (1,2,3,4,5))

और परिणाम के रूप में सेट:

1_COL            2_COL            3_COL            4_COL            5_COL           
---------------- ---------------- ---------------- ---------------- ----------------
TABLE 1 COLUMN 3 TABLE 1 COLUMN 1 TAB1_COL_5       TABLE 1 COLUMN 2 TABLE 1 COLUMN 4

आप पिवट के लिए pos . के बजाय स्तंभ नामों का उपयोग कर सकते हैं , यह मेरे विचार से पढ़ना और भी कठिन बना देगा, क्योंकि आपको उनके चारों ओर उद्धरण शामिल करने की आवश्यकता होगी।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracle क्लाउड और ऑटोनॉमस डेटाबेस पर निःशुल्क प्रमाणन परीक्षा की नई तिथियां

  2. ओरेकल क्वेरी को कैसे अनुकूलित करें जिसमें तारीख के लिए खंड में to_char है

  3. Oracle त्रुटि ORA-28759:utl_http पैकेज का अनुरोध करते समय फ़ाइल खोलने में विफलता

  4. nhibernate, Oracle में कॉल फ़ंक्शन जो sys refcursor लौटाता है

  5. Oracle:बाईं ओर बहुत बड़ी तालिका में शामिल हों और सम्मिलित पंक्तियों को सबसे बड़े फ़ील्ड मान के साथ एक तक सीमित करें