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

अंतिम टिप्पणी दिखाएं जो प्रति उपयोगकर्ता सिर्फ 1 टिप्पणी है

यह GROUP BY के साथ काम क्यों नहीं करता

SELECT * GROUP BY . के साथ प्रयोग नहीं किया जा सकता; यह अमान्य एसक्यूएल है। GROUP BY तालिका पंक्तियों का चयन नहीं करता है। यह प्रदान किए गए भावों का उपयोग करके पंक्तियों के समूह बनाता है, फिर प्रत्येक समूह से, यह एक नया रिकॉर्ड बनाता है और अभिव्यक्ति में शामिल मूल्यों का उपयोग करके इस नए रिकॉर्ड के प्रत्येक कॉलम की गणना करता है।

SELECT . में दिखने वाले कॉलम खंड को निम्नलिखित नियमों में से एक को पूरा करना चाहिए:

  • GROUP BY में भी दिखाई देते हैं खंड;
  • का उपयोग GROUP BY कुल कार्य ;
  • कार्यात्मक रूप से उन स्तंभों पर निर्भर हैं जो GROUP BY . में दिखाई देते हैं खंड।

जबकि * क्वेरी द्वारा उपयोग की जाने वाली तालिका (तालिकाओं) के सभी कॉलम नामों के लिए एक शॉर्टकट है, केवल आपकी क्वेरी के लिए user कॉलम उपरोक्त आवश्यकताओं में से एक को पूरा करता है।

संस्करण 5.7.5 से पहले MySQL ने ऊपर तीसरा नियम लागू नहीं किया। यह उन प्रश्नों को स्वीकार करता था जिनमें SELECT . होता है क्लॉज कॉलम जो किसी भी GROUP BY . का पालन नहीं करते हैं आवश्यकताएं। ऐसे कॉलम के लिए क्वेरी द्वारा दिया गया मान indeterminate था

संस्करण 5.7.5 के बाद से, MySQL GROUP BY . को अस्वीकार करता है क्वेरी जो आवश्यकताओं को पूरा करती हैं।

समाधान

किसी भी तरह से, आपकी समस्या के समाधान में GROUP BY शामिल नहीं है . इसे LEFT JOIN . का उपयोग करके आसानी से पूरा किया जा सकता है सही शर्तों के साथ:

SELECT lc.*
FROM comments lc               # 'lc' from 'last comment'
    LEFT JOIN comments nc      # 'nc' from 'newer comment'
        ON lc.user = nc.user   # both comments belong to the same user
        AND lc.id < nc.id      # 'nc' is newer than 'lc'
WHERE nc.id IS NULL            # there is no 'newer comment'
ORDER BY lc.id DESC
LIMIT 10

यह कैसे काम करता है

यह तालिका में शामिल हो जाता है comments , उपनाम lc . के रूप में (एक उपयोगकर्ता की "अंतिम टिप्पणी" से "lc") स्वयं के विरुद्ध, जिसका उपनाम nc . है ("एनसी" से "नई टिप्पणी")। जॉइन क्लॉज lc . की प्रत्येक प्रविष्टि से मेल खाता है nc . की सभी प्रविष्टियों के साथ जो एक ही उपयोगकर्ता से संबंधित हैं (lc.user = nc.user ) और नए हैं (lc.id < nc.id; मुझे लगता है कि आईडी क्रमिक रूप से असाइन किए गए हैं और नई टिप्पणियों में id . के लिए बड़े मान हैं )।

LEFT JOIN . का उपयोग सुनिश्चित करता है कि lc . की प्रत्येक पंक्ति शामिल होने के परिणाम में प्रकट होता है, तब भी जब nc . में कोई मिलान पंक्ति नहीं मिलती है (क्योंकि एक ही उपयोगकर्ता की कोई नई टिप्पणी नहीं है)। इस मामले में, NULL nc . के क्षेत्रों के बजाय प्रयोग किया जाता है . WHERE क्लॉज अंतिम परिणाम में केवल उन पंक्तियों को सेट करता है जिनमें NULL है nc.id . में; इसका मतलब lc . में है उनमें प्रत्येक उपयोगकर्ता की नवीनतम टिप्पणी शामिल है।

SELECT क्लॉज में lc . के सभी क्षेत्र शामिल हैं (उनमें से nc सभी NULL हैं , वैसे भी)। ORDER BY क्लॉज का उपयोग परिणाम सेट को सॉर्ट करने के लिए किया जा सकता है। ORDER BY lc.id DESC सबसे हाल की टिप्पणियों को पहले रखता है और LIMIT क्लॉज परिणाम को एक अच्छे आकार में सेट रखता है।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. एमएएमपी प्रो mysql प्रारंभ नहीं हो सकता

  2. आईडी को अल्पविराम से अलग किए गए मानों के रूप में संग्रहीत करना

  3. डेटाबेस व्यवस्थापन के लिए MySQL कार्यक्षेत्र स्थापित करें

  4. MySQL 3 टेबल्स में शामिल हों का चयन करें

  5. MySQL में SOUNDS LIKE ऑपरेटर कैसे काम करता है