mysql - SQL - sum (column 1 + column2 + column3 ) and select max value of sum in each group -


नमूना डेटा के साथ मेरी मेज है:

  आईडी | group_id | स्तम्भ 1 | कॉलम 2 | स्तम्भ 3 | -------------------------------------- 1 1 | 1 1 0 2 1 | 1 1 1 3 2 | 0 0 4 4 2 | 1 1 1 5 1 | 1 0 6 6 3 | 0 0 0  

अपेक्षित परिणाम सेट: (परिणामस्वरूप प्रत्येक समूह में अधिकतम राशि (कॉल 1 + कोला 2 + 3 का) दिखाई देनी चाहिए)

> <पूर्व> आईडी | समूह_आईड | कॉलम 1 | कॉलम 2 | स्तंभ 3 | -------------------------------------- 2 1 | 1 1 1 4 2 | 1 1 1 6 3 | 0 0 0

वास्तविक परिणाम सेट: (द्वारा My_table मीटर समूह से कुल के रूप में * का चयन करें, अधिकतम (m.column1 + m.column2 + m.column3) M.group_id) जो गलत है

  id | group_id | column1 | column2 | column3 | total | ------------------------------------------ 1 1 | 1 1 3 3 2 | 0 0 3 3 6 3 | 0 0 0 0  

मैं एसक्यूएल के लिए काफी नया हूँ, ऐसा लगता है कि क्वेरी प्रत्येक समूह में पहले आईडी का चयन कर रहा है।

अपेक्षित परिणाम प्राप्त करने का सबसे अच्छा तरीका क्या है?

आप प्राप्त कर सकते हैं एक subselect के साथ अपने वांछित परिणाम यानी:

पहले चरण:

 <कोड> का चयन करें मैक्स (m1.column1 + m1.column2 + m1.column3) से My_table एम 1 ग्रुप द्वारा m1.group_id  

group_id प्रति अधिकतम कुल मिल जाएगा।

क्योंकि गैर एकत्रित स्तंभ में मान indetermined कर रहे हैं, अगर यह कॉलम अलग मान हैं एक समूह के लिए, तो आप बस कुल के रूप में आपके द्वारा किए गए नहीं कर सकते हैं, लेकिन पहले कदम से क्वेरी का उपयोग कर एक subselect यह करना होगा:

पूर्ण क्वेरी

< का चयन करें *, m.column1 + m.column2 + m.column3 कुल My_table मीटर से कहां m.column1 + m.column2 + m.column3 = (मैक्स (चयन के रूप में> <कोड pre> m1.column1 + m1.column2 + एम 1 .column3) से my_table एम 1 WHERE m.group_id = m1.group_id GROUP द्वारा m1.group_id);


Comments

Popular posts from this blog

c++ - C/pp Sockets, recv()/send() works only under gdb -

GO: Serve static pages -

objective c - How to open front/back camera at the same time in iOS developing? -