QlikView - 增量加载

随着 QlikView 文档数据源中的数据量增加,加载文件所需的时间也会增加,从而减慢分析过程。一种最小化加载数据所需时间的方法是仅加载源中的新记录或更新的记录。将源中新的或更改的记录仅加载到 QlikView 文档中的概念称为增量加载

为了识别源中的新记录,我们对每行使用顺序唯一键或​​日期时间戳。这些唯一键或数据时间字段的值必须从源文件流向 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 文件。

 incr_laod_create_qvd

验证已加载的数据。

我们可以通过创建名为 Table Box 的工作表对象来检查已加载到 QlikView 文档的数据。此功能可在布局菜单和新工作表对象子菜单中找到。

table_box_option

创建表格布局

选择表格框工作表对象后,我们将进入下一个屏幕,该屏幕用于选择要创建的表格中的列及其位置。我们选择以下列及其位置,然后单击"完成"。

Incr_load_product_details

查看现有数据

以下图表显示了上一步中布置的数据。

incremental_load_data

更新源数据

让我们将以下三条记录添加到源数据中。此处,产品 ID 是代表新记录的唯一编号。

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

增量加载脚本

现在,我们编写脚本以仅从源中提取新记录。

// 从存储的 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 文件中。我们看到新产品 ID 为 13、14 和 15 的记录。

incremental_load_final_data