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

इस SQL ​​​​कथन को कैसे लिखें?

SELECT user.name, user.subject
FROM user
INNER JOIN (
    SELECT name, COUNT(1) AS occurrences
    FROM user
    GROUP BY name
  ) AS user_occurrences
  ON user.name = user_occurrences.name
ORDER BY user_occurrences.occurrences DESC, user.name ASC, user.subject ASC
LIMIT 4

संपादित करें आपके द्वारा उपयोग किए जा रहे RDBMS और डेटासेट के आकार के आधार पर यह बेहतर प्रदर्शन कर सकता है। दोनों को आजमाएं और तुलना करें।

SELECT user.name, user.subject
FROM user
INNER JOIN user AS user_occurrences
  ON user.name = user_occurrences.name
GROUP BY user.name --, user.subject Second GROUP BY not needed on MySQL, but it should logically be there
ORDER BY COUNT(user_occurrences.subject) DESC, user.name ASC, user.subject ASC
LIMIT 4


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. मेरी टेबल का आकार अपेक्षा से 4x बड़ा क्यों है? (पंक्तियाँ * बाइट्स / पंक्ति)

  2. डेटाबेस में बैंक जानकारी संग्रहीत करने के लिए सर्वोत्तम अभ्यास

  3. स्पष्ट_डिफॉल्ट्स_for_timestamp को कैसे सक्षम करें?

  4. SUM(users_count) 1000 . तक पहुंचने तक चयन करने के लिए एक SQL क्वेरी

  5. mysql में कई पंक्तियाँ डालें (अल्पविराम द्वारा अलग किए गए आइटम)