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

पिछले प्रश्न के उत्तर के आधार पर MCQ उत्तर गणना का चयन करें

यदि आप मॉड नहीं करना चाहते हैं, तो आपको इसके बजाय प्रश्न आईडी का चयन करना होगा। और मैंने क्रॉस जॉइन का उपयोग किया है कुछ अन्य खंड प्राप्त करने के लिए जहां प्रतिक्रिया नहीं है। और चुनिंदा कथन में, आप मामला सेगमेंटनाम को 0 पर गिनने के लिए स्टेटमेंट।

SELECT
    bb.name,
    s.name,
    CASE WHEN s.id IN(
        SELECT
            r.segment_id FROM brandlift_respondent r) THEN
        COUNT(q2ac.brand_id)
    ELSE
        0
    END AS CountNumber
FROM
    brandlift b
    LEFT JOIN brandlift_brand bb ON b.campaign_id = bb.campaign_id
    LEFT JOIN brandlift_respondent r ON b.campaign_id = r.campaign_id
    
    CROSS JOIN brandlift_segment s
    
    LEFT JOIN brandlift_question q1 ON b.campaign_id = q1.campaign_id AND q1.ordinal = 1
    LEFT JOIN brandlift_answer q1a ON r.id = q1a.respondent_id AND q1.id = q1a.question_id
    INNER JOIN brandlift_answer_content q1ac ON q1a.id = q1ac.answer_id AND q1ac.brand_id = 1 -- the "flagship brand" id
        
    LEFT JOIN brandlift_question q2 ON q1.campaign_id = q2.campaign_id AND q2.ordinal = 2
    LEFT JOIN brandlift_answer q2a ON q1a.respondent_id = q2a.respondent_id AND q2.id = q2a.question_id
    LEFT JOIN brandlift_answer_content q2ac ON q2a.id = q2ac.answer_id AND bb.id = q2ac.brand_id
WHERE
    b.campaign_id = :campaign_id -- parameter
    AND R.segment_id = s.id OR s.id NOT IN(SELECT r.segment_id FROM brandlift_respondent r)
GROUP BY
    bb.name,
    s.name,
    s.id

परिणाम इस तरह दिखता है




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. pg_restore चलाते समय फ़ाइल हेडर में [संग्रहकर्ता] असमर्थित संस्करण (1.13) प्राप्त करना

  2. एसक्यूएल में अंक के डेटाबेस से पथ प्राप्त करें

  3. http://localhost/phppgadmin/ -> 403 निषिद्ध

  4. पोस्टग्रेज करने के लिए csv फ़ाइल में मौजूद NULL मानों को कॉपी करें

  5. 'Npgsql.NpgsqlFactory' प्रकार के प्रदाता कारखाने के लिए प्रदाता का नाम निर्धारित करने में असमर्थ