2011-02-09 23 views
34

SQL sorguda birden çok sol birleştirmeyi kullanmak mümkün mü? değilse o zaman çözüm nedir?MULTIPLE SOL JOIN

LEFT JOIN 
     ab 
    ON 
     ab.sht = cd.sht 

Buna benzer bir sorguyu daha eklemek isterim? Çalışacak mı?

LEFT JOIN 
     ab AND aa 
    ON 
     ab.sht = cd.sht 
      AND 
        aa.sht = cc.sht 

Wil bu çalışma?

cevap

40

Evet, bu mümkün. Her bir katılma tablosu için bir ON'a ihtiyacınız var.

LEFT JOIN ab 
    ON ab.sht = cd.sht 
LEFT JOIN aa 
    ON aa.sht = cd.sht 

arada karmaşık SQL için benim kişisel biçimlendirme tercihi http://bentilly.blogspot.com/2011/02/sql-formatting-style.html açıklanmıştır. Çok fazla yazacaksanız, muhtemelen yardımcı olacaktır.

+0

Ne sen? Demek kod/sorguda açıklayabiliriz? – cute

+0

Küçük bir kod örneği ekledim. – btilly

17

Evet, ama sözdizimi gerekli SQL bazıları gibi olacak sen

SELECT 
    <fields> 
FROM 
    <table1> 
    LEFT JOIN <table2> 
     ON <criteria for join> 
     AND <other criteria for join> 
    LEFT JOIN <table3> 
     ON <criteria for join> 
     AND <other criteria for join> 
+0

JOIN'lerde AND ölçütlerini gösterdiğiniz için teşekkür ederiz. Bazı arama terimlerini yanlış bir şekilde WHERE maddesine taşıyarak kafamı kırıyordum! – Santosh

8

sahip olandan farklıdır: -

SELECT * FROM cd 
LEFT JOIN ab ON ab.sht = cd.sht 
LEFT JOIN aa ON aa.sht = cd.sht 
.... 

yardımcı olur Umut.

+1

SOL JOIN'leri bu biçimde görüntüleme, birbiri ardına gelen şeyleri gerçekten bir perspektife dönüştürür. –

0

You have iki seçenek, masanız sipariş bağlı

create table aa (sht int) 
create table cc (sht int) 
create table cd (sht int) 
create table ab (sht int) 

-- type 1  
select * from cd 
inner join cc on cd.sht = cc.sht 
LEFT JOIN ab ON ab.sht = cd.sht 
LEFT JOIN aa ON aa.sht = cc.sht 

-- type 2 
select * from cc 
inner join cc on cd.sht = cc.sht 
LEFT JOIN ab 
LEFT JOIN aa 
ON aa.sht = ab.sht 
ON ab.sht = cd.sht 
+0

çalışmıyor – cute

+0

@cute güncellenmiş yanıtı gör – RichardTheKiwi