MySQL, bir veritabanını yönetirken ihtiyaç duyulan birçok komutu sağlar. Örneğin, genellikle bazı koşullara bağlı olarak farklı tablolardan bazı veriler almamız gerekir. MySQL daha sonra istenen sonuçları elde etmek için farklı türde birleştirmeler sağlar. MySQL’in LEFT JOIN VE RIGHT JOIN’ini öğrenelim.
SQL’de FULL OUTER JOIN diye bir deyim yoktur, ancak aynı sonuçları elde etmek için basit bir JOIN kullanabiliriz veya iki farklı tablo üzerinde bir SELECT deyimi kullanabiliriz.
Aksi takdirde, MySQL sağlar SOL YÖNDEN KATILIM ve DOĞRU BİRLEŞTİR sırasıyla sağ veya sol tablodan kayıtları veya satırları almak için. Uygun birleşimleri kullanarak istenen sonuçları elde etmek için birkaç farklı örnek deneyelim.
Örnekler
LEFT ve RIGHT JOIN kullanımını öğrenmeye başlamadan önce. Basit SELECT deyimini kullanarak ve SELECT deyimiyle CROSS JOIN kullanarak her iki tablodan da (yaygın veya yaygın olmayan) tüm verileri nasıl alacağımızı öğreneceğiz. Öncelikle SELECT deyimini kullanarak her iki tablodan da tüm verileri almaya çalışalım.
Mesela yazar ve kitap isimlerine göre aldığımız 2 tablo var.
Her iki tablodan da tüm sütunları almak istiyorsak. SELECT sorgusu şu şekilde kullanılacaktır:
SEÇME*İTİBAREN kitabın, yazarlar;
Gördüğünüz gibi, her iki tablodaki tüm sütunlara bir koşul bile sağlamadan sahibiz.
JOIN veya CROSS JOIN yan tümcesini kullanırsak, her ikisi de bize aynı sonuçları getirecektir. Örneğin:
SEÇME*İTİBAREN kitabın KATILMAK yazarlar;
Şimdi CROSS JOIN’i uygulamaya çalışalım:
SEÇME*İTİBAREN kitabın GEÇMEKKATILMAK yazarlar;
Tanık olduğunuz gibi, tüm bu sorgular bize aynı sonuçları getiriyor.
Ancak, tüm sütunların böyle soyut bir biçimde olması iyi değildir. Bu nedenle, sol veya sağ tablodan birkaç özel sütun almak için iki şekilde ilerleyebilirsiniz; Bunun bir yolu, SELECT deyimlerini kullanarak veya gereksinimlerinize uyan birleşimleri kullanarak sütun adlarını kullanmanızdır.
Pekala, şimdi LEFT JOIN ve RIGHT JOIN’i anlamak için ilerleyelim.
SOL YÖNDEN KATILIM
Kitaplar tablosundan veya aşağıdakiler arasında ortak olan bazı belirli sütunları almak istediğimizi varsayalım. kitaplar ve yazarlar tablosu, bazı koşullara göre, aslında iki farklı koşul karşılaştırılarak sağlanır. tablolar. Örneğin, kitabın kimliğinin yazar kimliğine eşit olduğu iki tablo, kitap ve yazarı birleştirmek istiyoruz. LEFT Join with SELECT deyimini kullanarak böyle bir sonuç bekleyebiliriz; Kitaplar tablosundan veya yazarlardan almak istediğiniz sütun adlarını içeren sorguyu SEÇİN. LEFT JOIN ve koşulu içeren SELECT sorgusu şöyle olacaktır:
SEÇME kitaplar.kitap_adı, kitaplar.book_id, yazarlar.yetkili_kimliği,
yazarlar.author_fname, yazarlar.yazar_lname
İTİBAREN kitabın
AYRILDIKATILMAK yazarlar
ÜZERİNDE kitaplar.book_id = yazarlar.yetkili_kimliği;
Kitaplar tablosunu sol tarafta belirttiğimiz için, birleştirme kitaplar tablosundan bir satırın ID’sini alacak ve aynı ID numarasını yazar tablosunda arayacaktır. Aynı ID numarasını bulursa, yazarın tablosundan verilen sütunları da gösterecektir. Aksi takdirde, yazarın tablosunun sütunlarında NULL gösterecektir. Bu sorguyu çalıştıralım ve sonuçlara şahit olalım.
Gördüğünüz gibi, kitap tablo kimliğinin yazarın tablo kimliğine eşit olduğu her iki tablodan da satırlarımız var. Son satırda, yazarın tablosunda ID numarası 4 olmadığını da görebiliyoruz, bu yüzden ona karşı NULL döndürdü.
DOĞRU BİRLEŞTİR
Benzer şekilde, ya yazarın tablosundan ya da kitaplar ve kitaplar arasındaki ortak verilerden bazı veriler elde etmek istiyorsak. yazarın tablosu, bazı koşullara bağlı olarak, RIGHT birleştirme ve SELECT kullanılarak bu tür sonuçlar beklenebilir. madde. RIGHT JOIN ve koşuluyla SELECT sorgusu şöyle olacaktır:
SEÇME kitaplar.kitap_adı, kitaplar.book_id, yazarlar.yetkili_kimliği,
yazarlar.author_fname, yazarlar.yazar_lname
İTİBAREN kitabın
SAĞKATILMAK yazarlar
ÜZERİNDE kitaplar.book_id = yazarlar.yetkili_kimliği;
Bu sefer yazarların tablosunun sağ tarafta olduğunu biliyoruz, bu nedenle birleştirme, yazarın tablosundan bir satırın kimliğini alacak ve kitabın tablosunda aynı kimlik numarasını arayacaktır. Aynı ID numarasını bulursa, kitaplar tablosundan verilen sütunları gösterecektir. Sorguyu yürütmek şuna neden olur:
Gördüğünüz gibi, yazar kimliğinin kitap kimliğine eşit olduğu her iki tablodan da satırlarımız var. Kitaplar tablosunda dördüncü bir kitap olduğunu biliyoruz, ancak alamadık, bunun nedeni RIGHT JOIN.
Yani, LEFT JOIN ve RIGHT JOIN gerçekten böyle çalışır.
Çözüm
CROSS, LEFT ve RIGHT JOIN’i öğrendik ve anladık ve MySQL’de istenen sonuçları elde etmek için bunları kullanmayı öğrendik. Ayrıca kavramları daha iyi ve derinlemesine anlamak için birkaç farklı JOINS örneğini denedik.
Diğer gönderilerimize göz at
[wpcin-random-posts]
İlk Yorumu Siz Yapın