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

एक ही कॉलम पर कई तालिकाओं में पूर्ण शामिल हों

कई तरीके हैं, लेकिन मुझे लगता है कि निम्नलिखित सबसे लोकप्रिय हैं:

select allk.k, t1.c1, t2.v2, t3.v3, t4.v4
from (select k from t1 union 
      select k from t2 union
      select k from t3 union
      select k from t4
     ) allk left outer join
     t1
     on allk.k = t1.k left outer join
     t2
     on allk.k = t2.k left outer join
     t3
     on allk.k = t3.k left outer join
     t4
     on allk.k = t4.k;

यदि आपके पास सभी k . की एक अलग तालिका है मान, आप इसका उपयोग allk . के बजाय कर सकते हैं सबक्वेरी।

अपना full outer join लिखने का एक आसान तरीका क्वेरी का उपयोग करना है coalesce() :

SELECT COALESCE(t1.K, t2.K, t3.K, t4.K) [K], V1, V2, V3, V4
FROM @T1 t1 FULL JOIN
     @T2 t2
     ON t2.K = t1.K FULL JOIN
     @T3 t3
     ON t3.K = coalesce(t1.K, t2.K) FULL JOIN
     @T4 t4
     ON t4.K = coalesce(t1.K, t2.K, t3.k);

और तीसरा तरीका है union all /group by विधि:

select k, max(v1) as v1, max(v2) as v2, max(v3) as v3, max(v4) as v4
from (select k, v1, NULL as v2, NULL as v3, NULL as v4
      from t1 union all
      select k, NULL as v1, v2, NULL as v3, NULL as v4
      from t2 union all
      select k, NULL as v1, NULL as v2, v3, NULL as v4
      from t3 union all
      select k, NULL as v1, NULL as v2, NULL as v3, v4
      from t4
     ) t
group by k;



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. डेटाबेस डिजाइन:खाता शेष की गणना

  2. एक पंक्ति में एकाधिक पंक्तियाँ और स्तंभ SQL को संयोजित करें

  3. थकाऊ या सीक्वेलाइज़ `findOne ()` . के लिए गलत सिंटैक्स का उपयोग करता है

  4. M1 Mac (ARM64) पर SQL सर्वर कैसे स्थापित करें

  5. क्या FixedLenNullInSource और TrimTrailingBlanks के मानों को बदलने का कोई तरीका है?