Sorun Cevaplayalım

İşinizle ilgili öngörüler edinin, gerçek zamanlı bilgilere göre karar alın.

SAP Eğitim ve Sertifika Dönemleri

Uzmanlığınızı ve deneyiminizi SAP çözümleri kullanarak tasdik edin.

Çözüm Ekibi Başvurusu

Kullanıcılara hızlı ve pratik çözümler üreterek görev almak isteyenler.

YANITLANDI Left outer to one join /left outer to many join

Bilgi Kaynak Erişimi
SAPOfis.com
Konu Kategorisi
ABAP Temel Bilgiler
Kullanıcı Değerlendirmesi
5.00 Oylama

hulagu504

Kayıtlı Üye
Katılım
9 Tem 2019
Mesajlar
3
Tepki Puanı
1
Puanları
3
Yaş
26
Kullandığınız SAP Modülleri
SAP MM, SAP FI, SAP SD, SAP HR, SAP ABAP
Katılım Bölgesi
Sivas
Merhabalar ,
incelediğim bir CDS yapısında left outer to one join ifadesi ile karşılaştım. Aradığımda ise aynı şekilde left outer to many join ifadesininde bulunduğunu gördüm.
Normal left outer join ile arasındaki farklar nelerdir ? Yardımcı olabilir misiniz? Cevaplarınız için şimdiden teşekkür ederim .
Saygılarımla.
 

Övünç DİNÇ

Çözüm Ekibi
Kayıtlı Üye
Katılım
8 Eki 2016
Mesajlar
913
Tepki Puanı
236
Puanları
43
Yaş
37
Konum
İzmir
Web Sitesi
sapofis.com
Kullandığınız SAP Modülleri
SAP MM, SAP PP
Katılım Bölgesi
İzmir
Merhabalar ,
incelediğim bir CDS yapısında left outer to one join ifadesi ile karşılaştım. Aradığımda ise aynı şekilde left outer to many join ifadesinin de bulunduğunu gördüm.
Normal left outer join ile arasındaki farklar nelerdir ? Yardımcı olabilir misiniz? Cevaplarınız için şimdiden teşekkür ederim .
Saygılarımla.
Daha önceki tablo birleştirme yazılarımda INNER JOIN’den bahsetmiştim. INNER JOIN ile iki tabloyu birleştirirken iki tablo arasında mutlaka tam bir eşleşme olması gerekmektedir. Ancak bazen öyle durumlar olur ki, iki tablo arasında birleştirme yapmamız gerekirken aynı zamanda bu tablolardan birindeki verilerin hepsinin de listelenmesini isteriz.

Örneğin bir e-ticaret sitesinde müşteriler ve aldıkları ürünlerini listelemek istediğimizi bununla birlikte henüz hiç alışveriş yapmayan müşterileri de listelemek istediğimizi varsayalım. İşte bu gibi durumlarda OUTER JOIN kullanmamız gerekiyor.

Böylelikle hem müşteriler tablosu ile aldıkları ürünleri siparişler tablosundan eşleştirerek listeleriz hemde müşteriler içinden henüz sipariş vermeyenleri de listeleme imkanına kavuşuruz.

OUTER JOIN kullanımı kendi içinde iki şekilde kullanılmaktadır. LEFT OUTER JOIN ve RIGHT OUTER JOIN.

LEFT OUTER JOIN: OUTER JOIN kullanırken mutlaka LEFT ya da RIGHT özelliklerinden hangisinin kullanılacağını belirtmemiz gerekiyor.

Peki nedir bu LEFT ve RIGHT?

Eğer birleştirdiğimiz iki tablo içinde tüm satırlarını göstermek istediğimiz ana tabloyu sorgumuzda sol tarafta yazıyorsak mutlaka LEFT OUTER JOIN kullanmamız gerekir. Örneğin aşağıdaki şekilde Sales.Customer ve Sales.SalesOrderHeader tablolarını LEFT OUTER JOIN ile birleştirdiğimiz de Sales.Customer tablosundaki tüm müşterilerin herhangi bir sipariş yapsalarda yapmasalar da listelenmesini sağlayacak birleştirme metodudur. Şekilde görülen gri alanda yer alan veriler bu sorguda listeleneceklerdir.

Yani Sales.Customer tablosunun tamamı ile Sales.Customer ve Sales.SalesOrderHeader tablolarının kesiştiği noktalar sorgumuzda listelenirler.

Left outer to one join /left outer to many join


Soruya Gelirsek,

Left outer to one join - left outer to many join arasında şu kurguyu düşünebilirsiniz.
Sadece bir işlem gören - birden fazla işlem gören (İşlem kelimesi prosese göre tanım değiştirir)
 
Üst