Birebir ilişki kılavuzu

Bu makale, Power BI Desktop'la çalışan veri modelleyicilerine yöneliktir. Size birebir modeli ilişkileriyle çalışma konusunda yol gösterir. Birebir ilişki, her iki tabloda da bir ortak ve benzersiz değerler sütunu bulunduğunda oluşturulabilir.

Not

Model ilişkilerine giriş konusu bu makalenin kapsamı dışındadır. İlişkileri, onların özelliklerini ve nasıl yapılandırılacağını tam olarak bilmiyorsanız, önce Power BI Desktop'ta model ilişkileri makalesini okumanızı öneririz.

Ayrıca yıldız şeması tasarımını anlamış olmanız da önemlidir. Daha fazla bilgi için bkz. Yıldız şemasını ve Power BI için önemini anlama.

Birebir ilişkiler içeren iki senaryo vardır:

  • Bozuk boyutlar: Olgu türündeki bir tablodan bozuk boyut türetebilirsiniz.

  • Tablolar arasına yayılan ham veriler: Tek bir iş varlığı veya konusu iki (veya daha çok) model tablosu olarak yüklenir. Bunun nedeni büyük olasılıkla bunların veri kaynaklarının farklı veri depoları olmasıdır. Boyut türündeki tablolar için bu yaygın bir senaryo olabilir. Örneğin ana ürün ayrıntıları operasyonel satış sisteminde, tamamlayıcı ürün ayrıntıları ise farklı bir kaynakta depolanıyordur.

    Öte yandan olgu türünde iki tabloyu ilişkilendirmek için birebir ilişki kullanılması alışılmışın dışında bir durumdur. Bunun nedeni olgu türündeki her iki tablonun da aynı boyut ve ayrıntı düzeyine sahip olmasının gerekmesidir. Ayrıca model ilişkisinin oluşturulabilmesi için olgu türündeki her tablonun benzersiz sütunları olması gerekir.

Bozuk boyutlar

Olgu türündeki bir tablodaki sütunlar filtrelemek veya gruplandırmak için kullanıldığında, bunları ayrı bir tabloda kullanıma sunmayı göz önünde bulundurabilirsiniz. Bu yolla, filtrelemek veya gruplandırmak için kullanılan sütunları olgu satırlarını özetlemek için kullanılan sütunlardan ayırırsınız. Bu ayrım şunları sağlayabilir:

  • Depolama alanını azaltma
  • Model hesaplamalarını basitleştirme
  • Geliştirilmiş sorgu performansına katkıda bulunma
  • Rapor yazarlarınıza daha sezgisel bir Alanlar bölmesi deneyimi sağlama

Satış siparişi ayrıntılarının iki sütunda depolandığı bir kaynak satış tablosu düşünün.

Satış tablosunun tablo satırları.

OrderNumber sütununda sipariş numarası ve OrderLineNumber sütununda siparişin içindeki satırların sırası depolanır.

Aşağıdaki model diyagramında sipariş numarası (OrderNumber) ve sipariş satırı numarası (OrderLineNumber) sütunlarının Sales tablosuna yüklenmediğine dikkat edin. Bunun yerine bu sütunların değerleri SalesOrderLineID adlı bir vekil anahtar sütunu oluşturmak için kullanılmıştır. (Anahtar değeri, sipariş numarası 1000 ile çarpılıp ardından sipariş satırı numarası toplanarak hesaplanır.)

Model diyagramı iki tablo içerir: Sales ve Sales Order. Birebir ilişki, SalesOrderLineID sütunlarını ilişkilendirir.

Sales Order tablosu üç sütunuyla rapor yazarlarına zengin bir deneyim sağlar: Sales Order, Sales Order Line ve Line Number. Ayrıca bir de hiyerarşi içerir. Bu rapor kaynakları siparişleri veya sipariş satırlarını filtrelemesi, gruplandırması veya bunlarda detaya gitmesi gereken rapor tasarımlarını destekler.

Sales Order tablosu satır verilerinden türetildiğinden, her tabloda tam olarak aynı sayıda satır bulunmalıdır. Dahası her SalesOrderLineID sütununda da eşleşen değerler yer almalıdır.

Tablolar arasına yayılan ham veriler

Birebir ilişkili iki boyut türünde tablo içeren bir örnek düşünün: Product (Ürün) ve Product Category (Ürün Kategorisi). Each table represents imported data and has a SKU (Stock-Keeping Unit) column containing unique values.

Burada iki tablonun kısmi bir model diyagramı verilmiştir.

Model diyagramı iki tablo içerir. Tasarım aşağıdaki paragrafta açıklanmıştır.

İlk tablo Product adlı tablodur ve üç sütunu vardır: Color, Product ve SKU. İkinci tablo Product Category adlı tablodur ve iki sütunu vardır: Category ve SKU. Birebir ilişki, SKU sütunlarını ilişkilendirir. İlişki her iyi yönde de filtreleme yapar ve bu durum birebir ilişkilerde her zaman geçerlidir.

İlişki filtresi yayma işleminin çalışmasını açıklamaya yardımcı olmak için, model diyagramı tablo satırlarını ortaya koymak için değiştirilmiştir. Bu makaledeki tüm örneklerde bu veriler temel alınmıştır.

Not

Power BI Desktop model diyagramında tablo satırlarını görüntülemek mümkün değildir. Bu makalede açıklamayı net örneklerle desteklemek için yapılmıştır.

Model diyagramı şimdi tablo satırlarını ortaya koyar. Satır ayrıntıları aşağıdaki paragrafta açıklanmıştır.

İki tablonun satır ayrıntıları aşağıdaki madde işaretli listede açıklanır:

  • Product tablosunun üç satırı vardır:
    • SKU CL-01, Product T-shirt, Color Green
    • SKU CL-02, Product Jeans, Color Blue
    • SKU AC-01, Product Hat, Color Blue
  • Product Category tablosunun iki satırı vardır:
    • SKU CL-01, Category Clothing
    • SKU AC-01, Category Accessories

Product Category tablosunda Product SKU CL-02 satırının olmadığına dikkat edin. Bu eksik satırın sonuçlarını bu makalenin devamında açıklayacağız.

Alanlar bölmesinde rapor yazarları iki tabloda yer alan ürünle ilgili alanları bulacaktır: Product ve Product Category.

Alanlar bölmesi iki tabloyu da genişletilmiş olarak gösteriyor ve sütunlar alan olarak listelenmiş. Product ve Product Category vurgulanmış.

Şimdi her iki tablodaki alanlar da bir tablo görseline eklendiğinde ne olduğuna bakalım. Bu örnekte SKU sütunun kaynağı Product tablosudur.

Tablo görselinde dört sütun vardır: SKU, Product, Color ve Category. Product SKU CL-02 için Category değeri BOŞTUR.

Product SKU CL-02 için Category değerinin BOŞ olduğuna dikkat edin. Bunun nedeni Product Category tablosunda bu ürün için satır bulunmamasıdır.

Öneriler

Satır verileri model tabloları arasına yayıldığında birebir model ilişkileri oluşturmaktan mümkün olduğunca kaçınmanızı öneririz. Çünkü bu tasarım:

  • Gereğinden fazla tablo listeleyerek Alanlar bölmesinde kalabalığı artırır
  • İlgili alanlar birden çok tabloya dağılmış olduğundan rapor yazarlarının bunları bulmasını zorlaştırır
  • Hiyerarşi düzeylerinin aynı tablodaki sütunları temel alması gerektiğinden hiyerarşi oluşturma becerisini sınırlandırır
  • Tablolar arasında tamamlanmış bir eşleşme olmadığından beklenmeyen sonuçlar doğurur

Belirli öneriler, birebir ilişkinin kaynak grubu içinde ya da kaynak grupları arasında olmasına bağlı olarak değişiklik gösterir. İlişkinin değerlendirmesi hakkında daha fazla bilgi için bkz. Power BI Desktop’ta model ilişkileri (İlişki değerlendirmesi).

Kaynak grubu içinde birebir ilişki

Tablolar arasında kaynak grubu içinde birebir ilişki olduğunda, verileri tek bir model tablosunda birleştirmenizi öneririz. Bu işlem Power Query sorguları birleştirilerek yapılır.

Aşağıdaki adımlarda birebir ilişkili verileri birleştirme ve modelleme yöntemi gösterilir:

  1. Sorguları birleştirme: İki sorguyu birleştirirken, her sorgudaki verilerin bütünlüğünü göz önünde bulundurun. Bir sorgu eksiksiz bir satır kümesi (ana liste gibi) içeriyorsa, diğer sorguyu onunla birleştirin. Varsayılan birleştirme türü olan sol dış birleştirmeyi kullanmak için birleştirme dönüştürmesini yapılandırın. Bu birleştirme türü ilk sorgunun tüm satırlarının tutulmasını ve bunların ikinci sorgudaki eşleşen satırlarla tamamlanmasını güvence altına alır. İkinci sorgunun tüm gerekli sütunlarını ilk sorguya genişletin.

  2. Sorgu yüklemeyi devre dışı bırak: İkinci sorgunun yüklemesini devre dışı bıraktığınızdan emin olun. Bu şekilde ikinci sorgu sonucunu bir model tablosu olarak yüklemez. Bu yapılandırma veri modeli depolama boyutunu azaltır ve Alanlar bölmesinde kalabalığı önlemeye yardımcı olur.

    Bizim örneğimizde, rapor yazarları artık Alanlar bölmesinde Product adlı tek bir tablo bulurlar. Bu tablo ürünle ilişkili alanları içerir.

    Alanlar bölmesinde iki tabloyu da genişletilmiş olarak gösteriyor ve sütunlar alan olarak listelenmiş. Product vurgulanmış.

  3. Eksik değerleri değiştir: İkinci sorguda eşleşmeyen satırlar varsa bu sorgudan eklenen sütunlarda NULL değerleri gösterilir. Uygun olduğunda NULL değerlerini bir belirteç değeriyle değiştirmeyi göz önünde bulundurun. Rapor yazarları sütun değerlerine göre filtreleme veya gruplandırma yaptığında eksik değerleri değiştirmek özellikle önemlidir çünkü rapor görsellerinde BOŞLUK görüntülenebilir.

    Aşağıdaki tablo görselinde SKU CL-02 ürününün kategorisinde [Tanımsız] ifadesinin gösterildiğine dikkat edin. Sorguda null kategoriler bu belirteç metin değeriyle değiştirilmiştir.

    Tablo görselinde dört sütun vardır: SKU, Product, Color ve Category. Product SKU CL-02 için Category değeri artık “Tanımsız” olarak etiketlenmiştir.

  4. Hiyerarşileri oluştur: Artık birleştirilmiş olan tablonun sütunları arasında ilişkiler varsa hiyerarşi oluşturmayı göz önünde bulundurun. Bu şekilde rapor yazarları rapor görselinde detaya gitme fırsatlarını hızla belirleyebilir.

    Bizim örneğimizde rapor yazarları artık iki düzeyi olan bir hiyerarşi kullanabilir: Category ve Product.

    Alanlar bölmesi iki tabloyu da genişletilmiş olarak gösteriyor ve sütunlar alan olarak listelenmiş. Products vurgulanmış.

Ayrı tabloların alanlarınızı düzenlemeye yardımcı olmasından memnun olsanız bile, yine de tek tabloda birleştirmenizi öneririz. Alanlarınızı yine düzenleyebilirsiniz ama bu kez görüntü klasörlerini kullanırsınız.

Bizim örneğimizde rapor yazarları Category alanını Marketing görüntü klasöründe bulabilir.

Alanlar bölmesinde Category alanı Marketing adlı bir görüntü klasörü içinde yer alır.

Modelinizde kaynak grubu içinde birebir ilişki tanımlamaya karar verirseniz, mümkün olduğunda ilişkili tablolarda eşleşen satırlar olduğundan emin olun. Kaynak grubu içinde birebir ilişki normal bir ilişki olarak değerlendirildiğinden, rapor görsellerinizde BOŞLUKLAR halinde veri bütünlüğü sorunları ortaya çıkabilir. (Bu makalede tanıtılan ilk tablo görselinde BOŞLUK gruplandırmasının bir örneğini görebilirsiniz.)

Kaynak grupları arasında birebir ilişki

Tablolar arasında kaynak grupları arasında birebir ilişki varken veri kaynaklarınızdaki verileri önceden birleştirmediğiniz sürece alternatif bir model tasarımı yoktur. Power BI birebir model ilişkisini sınırlı bir ilişki olarak değerlendirecektir. Bu nedenle ilişkili tablolarda eşleşen satırların bulunduğundan emin olun çünkü eşleşmeyen satırlar sorgu sonuçlarından çıkarılır.

Şimdi her iki tablodaki alanlar bir tablo görseline eklendiğinde ve tablolar arasında sınırlı ilişki olduğunda neler olduğuna bakalım.

Tablo görselinde dört sütun vardır: SKU, Product, Color ve Category. Tablonun yalnızca iki satırı vardır.

Tablo yalnızca iki satır görüntüler. Product SKU CL-02 eksiktir çünkü Product Category tablosunda bununla eşleşen bir satır yoktur.

Sonraki adımlar

Bu makaleyle ilgili daha fazla bilgi için aşağıdaki kaynaklara bakın: