QlikView-インクリメンタルロード

QlikViewドキュメントのデータソース内のデータ量が増えると、ファイルのロードにかかる時間も長くなり、分析プロセスが遅くなります。データのロードにかかる時間を最小限に抑える1つの方法は、ソースで新しいレコードまたは更新されたレコードのみをロードすることです。新しいレコードまたは変更されたレコードのみをソースからQlikViewドキュメントにロードするというこの概念は、Incremental Load

ソースからの新しいレコードを識別するために、各行に連続した一意のキーまたは日付のタイムスタンプを使用します。一意キーまたはデータ時間フィールドのこれらの値は、ソースファイルからQlikViewドキュメントに流れる必要があります。

小売店の製品の詳細を含む次のソースファイルについて考えてみましょう。これを.csvファイルとしてローカルシステムに保存し、QlikViewからアクセスできるようにします。一定期間にわたって、さらにいくつかの製品が追加され、いくつかの製品の説明が変更されます。

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

QlikViewへのデータのロード

スクリプトエディタ(Control + E)を使用して、以下に示すように[テーブルファイル]オプションを選択して、上記のCSVファイルを読み込みます。ここでは、ローカルシステムのQVDファイルにもデータを保存します。QlikViewドキュメントを.qvwファイルとして保存します。

ロードされたデータの確認。

QlikViewドキュメントに読み込まれたデータを確認するには、次のシートオブジェクトを作成します。 Table Box。これは、レイアウトメニューとNew Sheet Objects サブメニュー。

テーブルレイアウトの作成

を選択すると Table Boxシートオブジェクト、次の画面に移動します。この画面は、作成するテーブル内の列とその位置を選択するために使用されます。次の列とその位置を選択して、[完了]をクリックします。

既存のデータの表示

前のステップでレイアウトされたデータを示す次のグラフが表示されます。

ソースデータの更新

次の3つのレコードをソースデータに追加しましょう。ここで、製品IDは一意の番号であり、新しいレコードを表します。

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

インクリメンタルロードスクリプト

ここで、ソースから新しいレコードのみをプルするスクリプトを記述します。

// 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);

上記のスクリプトは、qvdファイルにロードおよび保存される新しいレコードのみをフェッチします。新しい製品ID13、14、および15のレコードが表示されます。