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のレコードが表示されます。