QlikView - Beban Tambahan

Saat volume data dalam sumber data dokumen QlikView meningkat, waktu yang dibutuhkan untuk memuat file juga meningkat yang memperlambat proses analisis. Salah satu pendekatan untuk meminimalkan waktu yang dibutuhkan untuk memuat data ini adalah dengan memuat hanya catatan yang baru di sumber atau yang diperbarui. Konsep memuat hanya catatan baru atau yang diubah dari sumber ke dalam dokumen QlikView disebutIncremental Load.

Untuk mengidentifikasi catatan baru dari sumber, kami menggunakan kunci unik berurutan atau stempel waktu tanggal untuk setiap baris. Nilai kunci unik atau bidang waktu data ini harus mengalir dari file sumber ke dokumen QlikView.

Mari kita perhatikan file sumber berikut yang berisi detail produk di toko ritel. Simpan ini sebagai file .csv di sistem lokal yang dapat diakses oleh QlikView. Selama periode waktu beberapa produk ditambahkan dan deskripsi beberapa perubahan produk.

Product_Id,Product_Line,Product_category,Product_Subcategory
1,Sporting Goods,Outdoor Recreation,Winter Sports & Activities
2,"Food, Beverages & Tobacco",Food Items,Fruits & Vegetables
3,Apparel & Accessories,Clothing,Uniforms
4,Sporting Goods,Athletics,Rugby
5,Health & Beauty,Personal Care
6,Arts & Entertainment,Hobbies & Creative Arts,Musical Instruments
7,Arts & Entertainment,Hobbies & Creative Arts,Orchestra Accessories
8,Arts & Entertainment,Hobbies & Creative Arts,Crafting Materials
9,Hardware,Tool Accessories,Power Tool Batteries
10,Home & Garden,Bathroom Accessories,Bath Caddies
11,"Food, Beverages & Tobacco",Food Items,Frozen Vegetables
12,Home & Garden,Lawn & Garden,Power Equipment

Memuat Data ke QlikView

Kami akan memuat file CSV di atas menggunakan editor skrip (Control + E) dengan memilih opsi File Tabel seperti yang ditunjukkan di bawah ini. Di sini kami juga menyimpan data ke dalam file QVD di sistem lokal. Simpan dokumen QlikView sebagai file .qvw.

Memverifikasi Data yang Dimuat.

Kita dapat memeriksa data yang dimuat ke dokumen QlikView dengan membuat objek sheet bernama Table Box. Ini tersedia di menu Tata Letak danNew Sheet Objects sub-menu.

Membuat Tata Letak Tabel

Saat memilih Table Boxobjek lembar, kita sampai ke layar berikutnya, yang digunakan untuk memilih kolom dan posisinya di tabel yang akan dibuat. Kami memilih kolom berikut dan posisinya dan klik Selesai.

Melihat Data yang Ada

Bagan berikut yang menunjukkan data seperti yang ditata pada langkah sebelumnya muncul.

Memperbarui Data Sumber

Mari kita tambahkan tiga record lagi berikut ke data sumber. Di sini, ID Produk adalah nomor unik, yang mewakili catatan baru.

13,Office Supplies,Presentation Supplies,Display
14,Hardware,Tool Accessories,Jigs
15,Baby & Toddler,Diapering,Baby Wipes

Skrip pemuatan tambahan

Sekarang, kita menulis skrip untuk menarik hanya record baru dari sumbernya.

// Load the data from the stored qvd.
Stored_Products:
LOAD Product_Id, 
     Product_Line, 
     Product_category, 
     Product_Subcategory
FROM
[E:\Qlikview\data\products.qvd]
(qvd);

//Select the maximum value of Product ID.
Max_Product_ID:
Load max(Product_Id) as MaxId
resident Stored_Products;

//Store the Maximum value of product Id in a variable.
Let MaxId = peek('MaxId',-1);

	 drop table Stored_Products;


//Pull the rows that are new.	 
NewProducts:
LOAD Product_Id,Product_Line, Product_category,Product_Subcategory
	 from [E:\Qlikview\data\product_categories.csv]
	 (txt, codepage is 1252, embedded labels, delimiter is ',', msq)
	 where Product_Id > $(MaxId);
	 
//Concatenate the new values with existing qvd.
Concatenate
LOAD Product_Id,Product_Line, Product_category, 
     Product_Subcategory
FROM [E:\Qlikview\data\products.qvd](qvd);

//Store the values in qvd.
store NewProducts into [E:\Qlikview\data\products.qvd](qvd);

Skrip di atas hanya mengambil record baru, yang dimuat dan disimpan ke dalam file qvd. Seperti yang kita lihat catatan dengan ID Produk baru 13, 14 dan 15.