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

ओरेकल क्वेरी का अनुकूलन

सबसे पहले, distinct . की कोई आवश्यकता नहीं है . क्वेरी को इस प्रकार लिखा जा सकता है:

select * 
  from [email protected] 
 where column1 in (
          select column2 
            from [email protected] 
           where column3 > 0
                  ) 
order by column1

दूसरा, इसे लिखने के (कम से कम) दो और तरीके हैं। या तो JOIN . के साथ :

select t1.* 
  from [email protected] t1
  join [email protected] t2
 where t2.column2 = t1.column1
   and t2.column3 > 0 
group by
       t1.id, t1.column1, ... 

order by t1.column1

या (मेरी प्राथमिकता) EXISTS . के साथ :

select t1.* 
  from [email protected] t1 
 where exists
       ( select *
           from [email protected] 
          where t2.column2 = t1.column1
            and t2.column3 > 0
                  ) 
order by column1

किसी भी मामले में, आपको उन सभी के लिए निष्पादन योजनाओं की जांच करनी चाहिए।

यदि आपके पास table1.column1 . पर एक अनुक्रमणिका है, तो मैं प्रदर्शन के सर्वोत्तम होने की अपेक्षा करता हूं और table2 . के लिए , या तो column2 . पर एक इंडेक्स या (column3, column2) . पर एक कंपोजिट इंडेक्स



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. ORA_HASH फ़ंक्शन द्वारा उपयोग किया जाने वाला एल्गोरिथम क्या है?

  2. OracleConnection.Open ORA-12541 TNS कोई श्रोता नहीं फेंक रहा है

  3. फॉर लूप में अभिव्यक्ति द्वारा कनेक्ट क्यों होता है, केवल एक बार निष्पादित होता है?

  4. ओरेकल 10 जी संग्रहीत प्रक्रिया से परिणाम प्रदर्शित करें

  5. ओरेकल रेगेक्स में कभी-कभी गैर लालची क्वांटिफायर क्यों काम नहीं करता है?