Ana içeriğe geç Tamamlayıcı içeriğe geç

Window - Komut dosyası fonksiyonu

Window() birden fazla satırdan hesaplamalar gerçekleştirerek her satır için ayrı bir değer üretir.

Aşağıdakiler gibi işlemleri yapmak için Window fonksiyonlarını kullanabilirsiniz:

  • Bir satırdaki tek bir sayı değerini sütundaki ortalama, maksimum veya minimum değerle karşılaştırma.

  • Sütun içinde veya tüm tablo içinde tek bir değerin sıralamasını hesaplama.

Window fonksiyonu tablodaki kayıt sayısını değiştirmez ancak yine de toplama, ilişkisel ve aralık işlevleriyle benzer görevleri yerine getirebilir.

Tabloya eklemek için Window işlevinin, üzerinde çalıştığınız tablonun LOAD ifadesi içinde bir önbelleğe sahip olması gerekir. Örneğin:

[Transactions]: Load *, Window(avg(Expression1),[Num]); LOAD TransLineID, TransID, "Num", Dim1, Dim2, Dim3, Expression1, Expression2, Expression3 FROM [lib://DataFiles/transactions.qvd] (qvd);FROM [lib://AttachedFiles/transactions.qvd] (qvd);

Window, yuvarlama veya temel sayısal işlemler gibi genel fonksiyonları destekler. Örneğin:

Load *, Round(Window(Sum(Salary),Department)) as SumSalary
Load *, Window(Sum(Salary),Department) + 5 as SumSalary

Window fonksiyonu için bir kayar pencere tanımlayabilirsiniz. Bu, geçerli satıra Window işlevi uygulanırken kullanılan satır sayısını ayarlar. Örneğin, pencereyi önceki 3 satır ve sonraki 3 satır olacak şekilde ayarlayabilirsiniz:

Window(avg(Salary), Department, 'NONE' -3, 3) as AvgDepSalary

Söz Dizimi:  

Window (input_expr, [partition1, partition2, ...], [sort_type, [sort_expr]],[filter_expr], [start_expr,end_expr])

Dönüş verileri türü: İfadeLOAD tarafından oluşturulan sonuç tablosuna eklenen yeni bir alan.

Bağımsız Değişkenler:  

Bağımsız Değişkenler
Bağımsız DeğişkenAçıklama
input_expr

Giriş ifadesi, fonksiyon tarafından hesaplanır ve döndürülür. Bu, Median(Salary) gibi bir toplamaya dayanan herhangi bir ifade olmalıdır. Örneğin:

Window(Median(Salary)) as MedianSalary

Giriş, toplama uygulanmamış bir alan adı da olabilir. Böyle bir durumda Window, bunu, Only() fonksiyonu o alana uygulanmış gibi işler. Örneğin:

Window(Salary,Department) as WSalary

 

İsteğe bağlı olarak, bölmelere ayırmayı giriş ifadesiyle tanımlayabilirsiniz. Bölmelere ayırma, group by cümlesiyle elde edilen gruplama ile aynıdır; tek fark, sonucun girdi tablosuna yeni bir sütun olarak eklenmesidir. Bölmelere ayırma, girdi tablosunun kayıt sayısını azaltmaz. Birden fazla bölüm alanı tanımlanabilir.

Örnek: 

LOAD Window(Max(Sales), City, 'ASC', OrderDate, Sales > 300)
+ AddMonths(OrderDate,-6) as MAX_Sales_City_Last_6_Mos, Window(Avg(Sales), City, 'ASC', OrderDate, City = 'Portland')
+ AddMonths(OrderDate,-6) as Avg_Sales_Portland_Last_6_Mos, Window(Max(Sales), City, 'ASC', OrderDate, Sales > 300)
+ AddMonths(OrderDate,-12) as MAX_Sales_City_Last_12_Mos; LOAD City, Sales, OrderDate FROM [lib://:DataFiles/Sales Data.xlsx]FROM [lib://AttachedFiles/Sales Data.xlsx] (ooxml, embedded labels, table is [Sales Data]);

partition1, partition2

input_expr sonrasında istediğiniz sayıda bölüm tanımlayabilirsiniz. Bölmeler, toplamalarla birlikte uygulanacak kombinasyonları tanımlayan alanlardır. Toplama, her bir bölmeyle ayrı olarak uygulanır. Örneğin:

Window(Avg(Salary), Unit, Department, Country) as AvgSalary

Yukarıdaki bölmeler: Unit, Department ve Country.

Bölmeler zorunlu değildir, ancak alanların uygun şekilde pencerelere ayrılması için gereklidir.

sort_type, [sort_expr]]

İsteğe bağlı olarak sıralama türünü ve sıralama ifadesini belirtin. sort_type iki değerden birine sahip olabilir:

  • ASC: Artan sıralama.

  • DESC: Azalan sıralama.

sort_type tanımlarsanız bir sıralama ifadesi tanımlamanız gerekir. Bu, bir bölmedeki satırların sırasına karar veren ifadedir.

Örneğin:

Window(RecNo(), Department, 'ASC', Year)

Yukarıdaki örnekte, Year alanına göre artan şekilde sıralanan bölme içinde sonuçlar bulunmaktadır.

Bilgi notuSıralama türü ve sıralama ifadesi öncelikle yalnızca RecNo ve WRank fonksiyonları ile gereklidir.
filter_expr

İsteğe bağlı olarak bir filtre ifadesi ekleyin. Bu, kaydın hesaplamaya dahil edilmesinin gerekip gerekmediğine karar veren bir Boolean ifadesidir.

Bu parametre tamamen atlanabilir ve sonuç, filtre bulunmaması olmalıdır.

Örneğin:

Window(avg(Salary), Department, 'ASC', Age, EmployeeID=3 Or EmployeeID=7)
as wAvgSalary) as wAvgSalaryIfEmpIs3or7
[start_expr,end_expr]

İsteğe bağlı olarak, kayar pencere işlevi için bağımsız değişkeni ayarlayın. Kayan pencere iki argüman gerektirir:

  • Başlangıç ifadesi: Pencereye dahil edilecek geçerli satırdan önceki satır sayısı.

  • Bitiş ifadesi: Pencereye dahil edilecek geçerli satırdan sonraki satır sayısı.

Örneğin, önceki 3 satırı, geçerli satırı ve sonraki satırı dahil etmek istiyorsanız:

Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, -3, 1)
as WSalaryDepartment

Tüm önceki satırları veya sonraki satırları belirtmek için Unbounded() fonksiyonunu kullanabilirsiniz. Örneğin, tüm önceki satırları, geçerli satırı ve sonraki satırı dahil etmek için:

Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, UNBOUNDED(), 1)
as WSlidingSalaryDepartment

Örneğin, geçerli satırdan üçüncü satırı ve tüm sonraki satırları dahil etmek için:

Window(concat(Text(Salary),'-'), Department, 'ASC', Age, Year>0, 3, UNBOUNDED())
as WSlidingSalaryDepartment

Örnek - Toplama içeren bir alan ekleme

Örnek - Belirli değerler için filtrelenmiş toplama içeren bir alan ekleme

Örnek - Kayan pencereli bir alan ekleme

Sınırlamalar

Window aşağıdaki sınırlamalara sahiptir:

  • Window, özellikle bellek tüketimi açısından yoğun kaynak kullanan bir işlevdir.

  • Window, Qlik Sense Mobile uygulamasında desteklenmiyor.

  • Grafik ifadeleri Window öğesini desteklemez.

  • Window fonksiyonlarını diğer Window fonksiyonlarıyla iç içe geçiremezsiniz.

  • Window bir toplama işlevi içinde kullanılamaz.

  • Window öğesinin tablonun tamamını tarayabilmesi gerekir.

  • Kayar pencere işlevi kullanılırken WRank(), RecNo() ve RowNo(), Window ile birlikte kullanılamaz.

Bu sayfa size yardımcı oldu mu?

Bu sayfa veya içeriği ile ilgili bir sorun; bir yazım hatası, eksik bir adım veya teknik bir hata bulursanız lütfen bize bildirin!

Analiz Modernleştirme Programına katılın

Remove banner from view

Analiz Modernleştirme Programı ile değerli QlikView uygulamalarınızı ödün vermeden modernleştirin. Bize ulaşmak ve daha fazla bilgi almak için buraya tıklayın: ampquestions@qlik.com