QlikView - 星型模式

星型模式模型是一种数据模型,其中多个维度链接到单个事实表。当然,在更大的模型中,可以有多个事实表链接到多个维度和其他事实表。此模型的用处在于以最少的连接执行快速查询,各个表之间没有连接。事实表包含数据,这些数据是度量值并具有数值。计算应用于事实表中的字段。维度表的唯一键用于将其链接到 FAT 表,FAT 表也具有通常具有相同字段名称的键。因此,事实表包含整个维度表的键,并形成用于各种查询的连接主键。

输入数据

下面给出了一个表列表,其中包含来自不同供应商和地区的不同产品的数据。此外,供应发生在不同的时间间隔,这些时间间隔在时间维度表中捕获。

产品维度

它包含产品类别和产品名称。产品 ID 字段是唯一键。

ProductID,ProductCategory,ProductName
1,Outdoor Recreation,Winter Sports & Activities
2,Clothing,Uniforms
3,Lawn & Garden	Power, Equipment
4,Athletics,Rugby
5,Personal Care,Shaver
6,Arts & Entertainment,Crafting Materials
7,Hardware,Power Tool Batteries

区域维度

它包含供应商所在的区域名称。RegionID 字段是唯一键。

RegionID,Continent,Country
3,North America, USA
7,South America, Brazil
12,Asia,China
2,Asia,Japan
5,Europe,Belgium

供应商维度

它包含供应上述产品的供应商名称。SupplierID 字段是唯一键。

SupplierID,SupplierName
3S12,Supre Suppliers
4A15,ABC Suppliers
4S66,Max Sports
5F244,Nice Foods
8A45,Artistic angle

时间维度

包含上述产品供应的时间段。TimeID 字段是唯一的 Key。

TimeID,Year,Month
1,2012,Feb
2,2012,May
3,2012,Sep
4,2013,Aug
5,2014,Jan
6,2014,Nov

供应商数量事实

它包含供应数量值及其缺陷百分比。它通过同名键连接到上述每个维度。

ProductID,RegionID,TimeID,SupplierID,Quantity, DefectPercentage
1,3,3,5F244,8452,12
2,3,1,4S66,5124,8.25
3,7,1,8A45,5841,7.66
4,12,2,4A15,5123,1.25
5,5,3,4S66,7452,8.11
6,2,5,4A15,5142,3.66
7,2,1,4S66,452,2.06

加载脚本

使用脚本编辑器将上述数据加载到 QlikView 内存中。从文件菜单打开脚本编辑器或按 Control+E。从 文件中的数据 选项卡中选择 表格文件 选项并浏览包含上述数据的文件。单击 确定 并按 Control+R 将数据加载到 QlikView 的内存中。以下是读取上述每个文件后出现的脚本。

LOAD ProductID, 
     ProductCategory, 
     ProductName
FROM
[C:\Qlikview\images\StarSchema\Product_dimension.csv]
(txt, codepage is 1252, embedded labels, delimiter is ',', msq);

LOAD TimeID, 
     Year, 
     Month
FROM
[C:\Qlikview\images\StarSchema\Time.csv]
(txt, codepage is 1252, embedded labels, delimiter is ',', msq);

LOAD SupplierID, 
     SupplierName
FROM
[C:\Qlikview\images\StarSchema\Suppliers.csv]
(txt, codepage is 1252, embedded labels, delimiter is ',', msq);

LOAD RegionID, 
     Continent, 
     Country
FROM
[C:\Qlikview\images\StarSchema\Regions.csv]
(txt, codepage is 1252, embedded labels, delimiter is ',', msq);

LOAD ProductID, 
     RegionID, 
     TimeID, 
     SupplierID, 
     Quantity, 
     DefectPercentage
FROM
[C:\Qlikview\images\StarSchema\Supplier_quantity.csv]
(txt, codepage is 1252, embedded labels, delimiter is ',', msq);

星型模式数据模型

将上述数据读入 QlikView 内存后,我们可以查看数据模型,该模型以星型模式显示所有表、字段和关系。

starschema_model