oracle - Select Top (Max) Amount From Two Of Four Fields (Columns) -


मेरे पास यह क्वेरी है

  SELECT code, username, week1money, week2money, week3money, week4money से (--स्यूबक्वेयर यहां जाता है)   

शीर्ष दो हफ्तों का चयन करने के लिए, अर्थात् हफ्तों के उच्चतम मूल्य के साथ? मैं सटीक होने के लिए शीर्ष दो सप्ताह में राशि जोड़ना चाहता हूं।

अगर मैं सही समझता हूं तो आप 2 प्राप्त करना चाहते हैं प्रत्येक प्रति शीर्ष मूल्य (कोड, उपयोगकर्ता नाम) पंक्ति और (कोड, उपयोगकर्ता नाम) रिकॉर्डसेट की कुंजी है मान लीजिए कि आप दो शीर्ष सप्ताह उसी मूल्यों के साथ रख सकते हैं और आपके पास नल नहीं है यह समाधान में से एक हो सकता है:

  SQL & gt; टी के साथ (आईडी, कोड, सप्ताह 1, सप्ताह 2, सप्ताह 3, सप्ताह 4) 2 (3 का चयन करें 1, 'ए', 10, 15, 11, 8 दोहरी संघ से सभी 4 चुनें 2, 'बी', 7, 4, 2 , दोहरी यूनियन से 9 सभी 5 चुनें 3, 'सी', 3, 3, 1, 0 दोहरी 6) 7 आईडी चुनें, अधिकतम, अधिकतम (सप्ताह) पहले_टॉप, न्यूनतम (सप्ताह) next_top से (8 चयन आईडी, कोड, Row_number () से अधिक (आईडी द्वारा विभाजन, सप्ताह के अंत तक कोड ऑर्डर) rnk, सप्ताह 9 से (10 चयन करें t.id, t.code, 11 decode (r.rn, 1, week1,2, week2,3, week3, 4, हफ्ते 4) सप्ताह में 12 से, 13 (स्तर से जुड़ने के लिए दोहरे कनेक्शन से रावेनम आरएन का चयन करें; = 4) आर 14)) 15 जहां आरएनसी में (1,2) 16 समूह आईडी आईडी, कोड 17 / आईडी सी एफआईआरएसटीईटीओईएक्सटीओपी - --------- - ---------- ---------- 3 सी 3 3 1 एक 15 11 2 बी 9 7   

यदि आपके पास सप्ताह में गैर-रिक्त और भिन्न मान हैं तो आप कुछ ऐसा उपयोग कर सकते हैं:

  SQL & gt; टी के साथ (आईडी, कोड, सप्ताह 1, सप्ताह 2, सप्ताह 3, सप्ताह 4) 2 (3 का चयन करें 1, 'ए', 10, 15, 11, 8 दोहरी संघ से सभी 4 चुनें 2, 'बी', 7, 4, 2 , दोहरी यूनियन से 9 सभी 5 चुनें 3, 'सी', 3, 2, 1, दोहरी 6 से) 7 चुनिंदा आईडी, कोड 8, सबसे बड़ा (सप्ताह 1, सप्ताह 2, सप्ताह 3, सप्ताह 4) पहले_टॉप 9, सबसे बड़ा (10 मामला सप्ताह 1 और लेफ्टिनेंट; सबसे बड़ा (सप्ताह 1, सप्ताह 2, सप्ताह 3, सप्ताह 4) सप्ताह 1 और -1 ई 28 अंत, 11 मामले जब सप्ताह 2 और लेफ्टिनेंट; सबसे बड़ा (सप्ताह 1, सप्ताह 2, सप्ताह 3, सप्ताह 4) तो सप्ताह 2 दूसरा -1 ई 28 अंत, 12 मामले जब सप्ताह 3 और लेफ्टिनेंट; (सप्ताह 1, सप्ताह 2, सप्ताह 3, सप्ताह 4) तो सप्ताह 3 और -1 ई 28 अंत, 13 मामले जब सप्ताह 4 और लेफ्टिनेंट; सबसे बड़ा (सप्ताह 1, सप्ताह 2, सप्ताह 3, सप्ताह 4), तो सप्ताह 4 और -1e 28 अंत 14) दूसरे स्थान 15 टी 16 / आईडी से सी FIRST_TOP SECOND_TOP ---------- - ---------- ---------- 1 एक 15 11 2 बी 9 7 3 सी 3 2   

लेकिन सही समाधान प्राप्त करने के लिए अधिक विवरण आवश्यक हैं।

Comments

Popular posts from this blog

sonata admin - how to add ManyToOne property field in configureListfield in sonataAdmin -

wpf - ControlTemplate with changes for every class -

sql - Return Function using Cursor -