SQL ile ilgili geçen yazımızda genel SQL komutlarına giriş yapmış ve kullanımı hakkında örnekler vermiştik. Bu komutlar genel olarak tüm işlemlerinizde size yetecektir; ancak SQL “o kadarlık” bir dil değildir. Size daha sadece yolun başındayız diyebilirim…
Bu yazımızda SQL ile iki tabodaki ortak bir veriye göre bu iki tabloyu birleştirmeyi öğreneceğiz, yani JOIN ifadelerini…
Birleştirme ifadeleri INNER JOIN ve LEFT, RIGHT JOIN olmak üzere 2 ye ayrılır. Zamanı geldikçe her ikisini de kullanacaksınız. Bu yazımızda da aşağıdaki tablo yapısını kullanacağız.
tblKisiler | |
tblSiteler |
1) INNER JOIN
Inner Join ifadesi iki tablodaki ortak bir veriye göre bu iki tabloyu birleştirip tek bir sonuç almada kullanılır.
Yapısı:
FROM tablo1 INNER JOIN tablo2 ON tablo1.alan1 karsilastirmaOperatoru tablo2.alan2
Bölümler | Açıklama |
---|---|
tablo1, tablo2 | Verilerin birleştirileceği tabloların adları |
alan1, alan2 | Birleştirilecek alanların isimleri. Eğer bu alanlar sayı türünde değiller ise aynı veri türünde olmaları gerekir; ancak aynı isimde olmaları zorunlu değildir. |
karsilastirmaOperatoru | Herhangi bir ilişkisel karşılaştırma operatörü: “=,” “<,” “>,” “<=,” “>=,” veya “<>.” |
Inner join’i anlatmaya şöyle devam edelim; mesela ben tblKisiler tablomdaki kişilerin yaptığı sitelerin isimlerini almak istiyorum. Bunu yapabileceğim ortak alanlar ise tblKisiler tablosundaki fldID alanı ve fldSiteler tablosundaki fldUID alanı. Gördüğünüz gibi ikiside farklı bir isme sahip ama bana bu birleştirme işleminde yardımcı olacaklar.
SELECT tblKisiler.fldAD, tblKisiler.fldSoyad,tblSiteler.fldSiteAD from tblKisiler
INNER JOIN tblSiteler ON tblKisiler.fldID = tblSiteler.fldUID
Bu SQL bize kişilerin adını, soyadını ve yaptığı sitenin adını verecektir. Eğer bu yöntemi kullanmamış olsaydık bu verileri ekrana yazdırmak için iki tane sorgu kullanmak zorunda olacaktır.
Inner Join ile tüm alanları karşılaştırıp bağlayabilirsiniz; ancak Memo ve OLE Object alanlarını birleştirmek isterseniz hata alırsınız. Bu alanlarla JOIN işlemi yapmayınız.
Bir sorguda istediğiniz kadar Inner Join kullanabilirsiniz. Böylece sadece iki tabloyu değil; istediğiniz kadar tabloyu aynı anda birbirine bağlayabilirsiniz.
Inner Join, sadece iki tabloda da var olan verileri alır. Yani eğer tblKisiler tablosundaki bir kişinin tblSiteler tablosunda hiç kaydı olmasaydı yukarıdaki sorguda o kişi hiç seçilmeyecekti ve sonuçta çıkmayacaktı.
2) LEFT JOIN, RIGHT JOIN
Inner Join’e oldukça benzese de bu bağlama türünün bir farkı vardır. Inner Join, daha önce de dediğim gibi, sadece iki tabloda da var olan verileri esas alır; eğer bir tabloda karşılık yoksa, o kaydı hiç ekrana getirmez. Ancak LEFT veya RIGHT join ‘de istediğiniz yandaki (Left veya Right) tüm veriler ekrana gelir.Tanımı biraz karışık gibi de olsa, birazdan örneklerle daha iyi anlayacaksınız.
Yapısı:
FROM tablo1 [ LEFT | RIGHT ] JOIN tablo2 ON tablo1.alan1 karsilastirmaOperatoru tablo2.alan2
Bölümler | Açıklama |
---|---|
tablo1, tablo2 | Verilerin birleştirileceği tabloların adları |
alan1, alan2 | Birleştirilecek alanların isimleri. Eğer bu alanlar sayı türünde değiller ise aynı veri türünde olmaları gerekir; ancak aynı isimde olmaları zorunlu değildir. |
karsilastirmaOperatoru | Herhangi bir ilişkisel karşılaştırma operatörü: “=,” “<,” “>,” “<=,” “>=,” veya “<>.” |
Eğer bir sorgu da Right JOIN kullanırsanız,( tabloSOL.alan1 = tabloSAG.alan2 ), sağ taraftaki tabloda bulunan (tabloSAG) tüm veriler, soldaki tabloda olup olmadığına bakılmaksınız ekrana yazılacaktır. Karşılığı bulunanlarda gerekli veri ekranda yazacak olmayanlarda ise yazacaktır.
Eğer bir sorgu da Left JOIN kullanırsanız,( tabloSOL.alan1 = tabloSAG.alan2 ), sol taraftaki tabloda bulunan (tabloSOL) tüm veriler, sağdaki tabloda olup olmadığına bakılmaksınız ekrana yazılacaktır. Karşılığı bulunanlarda gerekli veri ekranda yazacak olmayanlarda ise yazacaktır.
Bu küçük fark dışında Inner Join ile benzerlik gösterir. Inner Join’de dikkat etmeniz gereken noktalara burada da dikkat etmelisiniz.
3) UNIOIN
Union komutu, iki ya da daha fazlanın sonuçlarını tek bir sonuç gibi ekrana yazdırır. Bu tablolarda herhangi bir kriter uyumu söz konusu olmayabilir.
UNION pek tercih edilmez ancak yine de nasıl kullandığını görmeniz açısından bir örnek yapalım. Ben aşağıdaki kod ile tblKisiler tablosundan fldAD alanını ve tblSiteler tablosundan, fldSiteAd alanını AD isimli yeni bir alan altında listeleteceğim. Sıra ile tüm kayıtlar aşağı doğru listelenecektir.
SELECT fldAd as AD from tblKisiler
UNION
Select fldSiteAD from tblSiteler
Union komutu ile ilgili bilmeniz gereken en önemli şey, SELECT ile aynı sayıda alan seçilmelidir; aksi takdirde hata mesajı ile karşılaşırsınız.
Instagram’da hikayenizi daha ilgi çekici hale getirmek için hikayenize müzik eklemeyi düşünebilirsiniz. Bunu yaparak hikayelerinizi…
iPhone yada Android telefonlarda bir QR kodu oluşturmak, WiFi şifrenizi paylaşmanızı kolaylaştıran en iyi yöntemlerin…
[Chorus] Got two girls in the cut And I don't know what to do I…
iOS 18'in Fotoğraflar uygulaması kafanızı mı karıştırdı? Yalnız değilsiniz. Apple, varsayılan Fotoğraflar uygulamasını iOS 18…
Meydana getirilen yeni bir araştırmaya gore, işlerin, projelerin teslim tarihini tutturmak oldukça mühim. Eğer bir…
OpenAI, iPhone'lardaki ChatGPT uygulamasına SearchGPT kestirmesi ekledi. MacRumors tarafınca fark edilen değişikliğe, Kestirmeleri açarak ulaşabiliyorsunuz.…