QlikWorld 2020 Global Konferans. Verilerinizden en iyi şekilde nasıl yararlanacağınızı keşfetmek için bize katılın. Fırsatı kaçırmayın. Şimdi kaydolun ve indirimden yararlanın.

Birleştirmeye alternatif olarak eşlemeyi kullanma

QlikView içindeki Join öneki, veri modelinde çeşitli veri tablolarını birleştirmenin güçlü bir yoludur. Bir dezavantajı ise birleştirilen tabloların büyük olabilmesi ve performans sorunları yaratabilmesidir. Başka bir tablodan tek değeri aramanız gerektiği durumlarda Join yönteminin bir alternatifi de eşlemeyi kullanmaktır. Birleştirme işlemleri tablolardaki kayıtların sayısını değiştirebildiğinden, bu yöntem, hesaplamaları yavaşlatan ve potansiyel olarak hesaplama hatalarına yol açabilen gereksiz verileri yüklemekten kurtulmanızı sağlayabilir.

Eşleme tablosu iki sütundan oluşur: bir karşılaştırma alanı (giriş) ve bir eşleme değeri alanı (çıkış).

Bu örnekte elimizde bir sipariş tablosu (Orders) var ve müşteri tablosunda (Customers) depolanan müşterinin ülkesini öğrenmemiz gerekiyor.

Orders veri tablosu
OrderID OrderDate ShipperID Freight CustomerID
12987 2007-12-01 1 27 3
12988 2007-12-01 1 65 4
12989 2007-12-02 2 32 2
12990 2007-12-03 1 76 3
Customers veri tablosu
CustomerID Name Country ...
1 DataSales Spain ...
2 BusinessCorp Italy ...
3 TechCo Germany ...
4 Mobecho France ...

Bir müşterinin ülkesini (Country) aramak için şuna benzer bir eşleme tablosuna gerek duyarız:

CustomerID Country
1 Spain
2 Italy
3 Germany
4 France

MapCustomerIDtoCountry olarak adlandırdığımız eşleme tablosu kodda şöyle tanımlanır:

MapCustomerIDtoCountry: Mapping LOAD CustomerID, Country From Customers ;

Bir sonraki adım, sipariş tablosunu yüklerken ApplyMap fonksiyonunu kullanarak eşlemeyi uygulamaktır:

Orders: S *, ApplyMap('MapCustomerIDtoCountry', CustomerID, null()) as Country From Orders ;

ApplyMap fonksiyonunun üçüncü parametresi, değerin eşleme tablosunda bulunamaması durumunda döndürülecek sonucu tanımlamak için kullanılır (bu örnekte Null()).

Sonuçta elde edilen tablo şöyle görünür:

OrderID OrderDate ShipperID Freight CustomerID Country
12987 2007-12-01 1 27 3 Germany
12988 2007-12-01 1 65 4 France
12989 2007-12-02 2 32 2 Italy
12990 2007-12-03 1 76 3 Germany