第一次接触cognos第6部分第一个元数据模型_第1页
第一次接触cognos第6部分第一个元数据模型_第2页
第一次接触cognos第6部分第一个元数据模型_第3页
第一次接触cognos第6部分第一个元数据模型_第4页
第一次接触cognos第6部分第一个元数据模型_第5页
已阅读5页,还剩22页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、体验魅力 cognos bi 10 系列,第 6 部分: 第一个元数据模型为什么需要元数据模型您已经熟悉使用 cognos 来创建报表,进行自助式设计分析,然而这些需要的创建的应用都依赖于对应的元数据模型,用户使用元数据模型对他们的数据源进行分析和报告。元数据模型是整个 cognos 应用的基础,它是一个或多个数据源中信息的业务演示。基于这个基础,您才能够创建报表,进行自助式设计分析。cognos 能支持多种数据源,包括关系型的和多维的数据库。元数据模型能隐藏底层数据源的复杂结构,可以更好地控制数据怎样展现给最终用户。元数据的组织和扩展就需要用到 cognos 的元数据模型设计工具 frame

2、work manger。cognos 的元数据模型设计工具 framework manger 可以连接企业的各种数据源(包括关系型数据库,多维数据库,文本,olap 等),对数据结构进行描述,为 cognos 的多维分析,即席查询,报表等各种应用提供统一一致的数据视图,降低对企业数据访问的复杂性,同时提供对各种应用使用的结构的统一的管理。cognos bi 10 的最新版本中在 framework manager 中增加了模型设计加速器,可以帮助开发人员更迅速、更轻松的创建新模型,并且模型优化时系统将充分利用知识库的经验。它的主要功能是: 帮助开发人员通过一个向导式的自动化工具,用快速简便的方

3、法创造新的建模框架。 从一个包含了知识库经验的模型开始建模,并添加更复杂的模型需求。 通过知识库的经验指导建模和帮助纠正和验证的常见错误。 第一个元数据模型1. 在开始菜单中启动 ibm cognos framework manager,选择 create a new project using model design accelerator。模型设计加速器适合于基于关系型数据库星形模型的元数据建模。星形模型是一种多维的数据关系,它由一个事实表(fact table)和一组维表(dimension table)组成。 2. 在“new project”中输入名称“第一个元数据模型”和目录位置

4、,如图 1 所示。当在 framework manager 中工作时,实际上是在一个 project 中进行操作的。project 以一个文件夹的形式出现在文件系统中,它包含一个 project 文件(.cpf) 和 xml 文件。 图 1. 项目3. 在登录窗口输入用户名和密码,在本教程中是 administrator 和 cognos,然后点击确定。语言选择“英文”,数据源选择“great_outdoors_warehouse”。 4. 在对象选择中,展开 gosalesdw 的 tables,选择以下表后点击 continue。 o go_time_dim o sls_order_met

5、hod_dim o sls_product_dim o sls_product_lookup o sls_product_type_lookup o sls_product_line_lookup o sls_sales_fact 5. 在 ibm cognos framework manager user guide 窗口中介绍了使用 model design accelerator 的步骤,您阅读后点击 close。 6. 在 model accelerator 面板,右键选择 fact query subject,选择 rename,输入 sales fact。 7. 在 explore

6、r tree 面板,展开 sls_sales_fact,选择以下字段拖拽到 sales fact 对象。 o quantity o unit_cost o unit_price o unit_sale_price o gross_margin o sale_total o gross_profit 8. 重命名 new query subject 1 为 products。 9. 在 explorer tree 面板: o 展开 sls_product_line_lookup 拖拽 product_line_en 到 products 对象。 o 展开 sls_product_type_loo

7、kup 拖拽 product_type_en 到 products 对象。 o 展开 sls_product_lookup 拖拽 product_ name 到 products 对象。 10. 对话框 relationship editing mode for: products 会弹出来,原因是 framework manager 无法检测出 sls_product_lookup 和 sls_sales_fact 的关系,因此需要手动指定。按住 ctrl 选择 sls_product_lookup 的 product_number 和 sls_product_dim 的 product_n

8、umber,点击左上角的 create a model relationship 按钮。在 modify the relationship 对话框中点击 ok,然后点击 ok 关闭 relationship editing mode for: products 对话框,如图 2 所示。 图 2. 关系11. 在 explorer tree 面板展开 sls_product_dim,选择以下字段拖拽到 products 对象。 o product_key o product_line_code o product_type_key o produtct_type_code o product_n

9、umber o product_image o introduction_date o discontinued_date 12. 重命名 new query subject 2 为 time。 13. 在 explorer tree 面板,展开 go_time_dim,选择 day_key 再按住 shift 键选择 weekday_en,把包含这两个字段的中间所有字段拖拽到 time 对象。 14. 重命名 new query subject 3 为 order methods。 15. 在 explorer tree 面板,展开 sls_order_method_dim,选择以下字段拖拽

10、到 order methods 对象。 o order_method_key o order_method_code o order_method_en 16. 最后在 model accelerator 面板的模型如图 3 所示。点击 generate model 按钮,提示框选择 yes,模型设计加速器会根据您的选择来生成模型。当生成结束后,ibm cognos framework manager 的界面就会展示在您的面前。 图 3. model accelerator17. 点击工具栏上的保存按钮,您的第一个元数据模型就创建成功了。 18. 在 framework manager 的 p

11、roject viewer 中可以看到模型的层次,如图 4 所示。模型设计加速器已经为您设计了模型的三个命名空间 physical view、business view 和 presentation view。 o physical view 是包含支持星型模型的表。 o business view 是包含需要的查询字段。 o presentation view 是包含在 business view 的快捷方式。 图 4. 模型的层次导入额外元数据模型前面您用 model design accelerator 构建了您的第一个元数据模型。接下来您可以用 metadata wizard 来手工添

12、加其他元数据,包括导入元数据,创建关系,更新 business view 和 presentation view。19. 在 ibm cognos framework manager 的 project viewer,右键选择 physical view 下面的 gosalesdw 命名空间,选择 run metadata wizard。 20. 选择 data sources 后 next。 21. 选择“great_outdoors_warehouse” 数据源后 next。 22. 在对象选择中,展开 gosalesdw 的 tables,选择 sls_sales_targ_fact 后

13、 next。 23. 选择 between each imported query subject and all existing query subjects in the model,如图 5 所示。点击 import 然后点击 finish。 图 5. 导入元数据24. 双击 gosalesdw 命名空间,然后选择 diagram 标签页来查看关系的图形,如图 6 所示。您可以看到刚导入的 sls_sales_targ_fact 没有对象连接,需要您手工创建。 图 6. diagram 关系图25. 在 project viewer 窗格,选择 go_time_dim 下的 month

14、_key ,再选择 sls_sales_targ_fact 下的 month_key,右键选择 create,再点击 relationship。关系定义对话框如图 7 所示,点击确定。 图 7. 关系定义26. 重复第 25 步,创建 sls_product_dim 和 sls_sales_targ_fact 在 product_type_key 字段的关系。 27. 在 project viewer 窗格,右键选择 business view 命名空间,点击创建,选择 query subject,输入 sales target fact 后点击 ok。 28. 在 query subject

15、 definition 窗口,在 available model objects 下展开 physical view,在 gosalesdw 下选择 sls_sales_targ_fact,把 sales_target 拖动到 query items and calculations 面板下,如图 8 所示。 图 8. 查询对象定义29. 在 business view 命名空间下点击刚才创建的 sales target fact 查询对象,按住 ctrl 再选择 products 和 time,也就是刚才定义过关系的维度,右键选择 create star schema grouping。在

16、create star schema grouping 对话框输入 sales target 后点击 ok,如图 9 所示。 图 9. 创建基于以事实为中心和其关联维度的模型30. 把刚才创建的 sales target 命名空间拖动到 presentation view 下。 31. 右键选择 presentation view 命名空间,点击 create,然后选择 namespace,把名字定义为 sales。接着把 sales fact、products、time 和 order methods 的快捷方式拖动到 sales 命名空间,如图 10 所示。 图 10. presentat

17、ion view 命名空间32. 点击工具栏上的保存按钮,您已经完成了导入额外元数据模型的工作。 设定 determinantsdeterminants 是 ibm cognos bi 的特性,通常来用来控制聚合的粒度。当维度数据和事实数据基于有重复值的粒度层次关联时候就需要 determinant。determinants 反映了代表查询对象的子集或集合,是用来保证准确的数据聚合。determinants 可以定义唯一标识一个数据集的数据库列集合,或者可以指定一个能够标识数据中的非唯一集的列集合。在您的元数据模型中,日期是时间的惟一性 determinants。而非惟一 determinan

18、ts 的例子是月份,在同月的时间中月份是重复的,在指定月份的非惟一 determinants 时候就要指明是 group by。这样就暗示 ibm cognos 在处理到非惟一 determinants 的属性时候有重复数据,需要采用聚合函数来避免重复计数。33. 在 project viewer 的 physical view 命名空间下,双击 go_time_dim 查询对象,然后点击 determinants 标签页。您可以看到只有根据主键的一个 determinant,下面您可以添加 year、quarter、month 作为 determinants。 34. 右键选择 pk,点击

19、rename,输入 day 然后回车。 35. 在 determinants 窗格,点击 add,右键选择 new determinant,点击 rename,输入 year 然后回车。 36. 选中 year,把 current_year 拖拽到 key 窗格。 37. 选择 year 旁边的 group by 的复选框。 38. 按照第 35 到 37 的步骤,添加 quarter 作为 determinant,quarter_key 拖拽到 key 窗格,选择 group by 的复选框。 39. 选中 quarter, 把 current_quarter 拖拽到 attributes

20、窗格。attributes 是与 determinant key 相关的数据项。如果 attributes 使用在报表中,则 key 就会用在基于聚合函数的 sql 中。 40. 按照第 35 到 37 的步骤,添加 month 作为 determinant,month_key 拖拽到 key 窗格,选择 group by 的复选框。 41. 选中 month, 把下列字段拖拽到 attributes 窗格。 o current_month o month_number o month_en 42. 通过上下箭头,调整顺序依次为 year、quarter、month 、day。最后点击 ok,

21、如图 11 所示。 图 11. determinants43. 在您的模型中 sls_product_dim 维度也存在类似的问题,您可以仿照上面的步骤,添加 product line 和 product type 两个 determinants,如图 12 所示。product line 的 key 是 product_line_code,而 product type 的 key 是 product_type_key。 图 12. sls_product_dim增加业务逻辑通常会把业务逻辑放在 business view 这个层次的,比如过滤和计算。有些时候为了考虑性能和维护成本,也会放到

22、physical view 这个层次。在您的模型中,sls_product_lookup 是支持多语言的,为了正确返回 product name,需要添加过滤条件。从性能角度考虑,这个过滤放在 physical view 这个层次可以避免返回额外的数据记录。过滤过滤被用来限制查询主题所检索的记录。framework manager 有两种过滤: 内嵌式 embedded :面向单个查询主题。 独立式 stand-alone :可重复使用。 接下来您将采用内嵌式过滤来让 sls_product_lookup 返回英文的产品名称。44. 在 project viewer 窗格,physical v

23、iew 下的 gosalesdw 命名空间,双击 sls_product_lookup,选择 filters 标签页,点击 add。在 name 编辑框输入 language filter。 45. 在 available components 面板里,双击 product_language。在 expression definition 面板输入 = en 。 framework manager 中的对象有一个标识符,可以拥有相同的名字,但是必须使用一个名字空间进行唯一标识。查询项有一个三部分的标识符 namespace.query subject.query item。46. 最后计算公式

24、为:gosalesdw.sls_product_lookup.product_language = en,如图 13 所示。然后点击 ok。 图 13. 内嵌式过滤47. 选择 test 标签页,点击 test sample,查看结果后再点击 ok。 回页首计算您可以创建计算来给报表作者提供他们经常使用的值。计算可以使用查询项、参数、函数。有两种类型的计算: 内嵌式 embedded :面向单个查询主题。 独立式 stand-alone :可重复使用。 接下来您将采用内嵌式计算来生成盈亏平衡点 quantity * unit cost。48. 在 project viewer 窗格,busin

25、ess view 命名空间下双击 sales fact,点击右下角的 add。在 name 编辑框输入 break even point。 49. 在 available components 窗格,双击 quantity。点击 functions 标签页,双击 *。点击 model 标签页,双击 unit cost。 50. 最后计算公式为:business view.sales fact.quantity * business view.sales fact.unit cost,如图 13 所示。点击 test sample 按钮,查看结果后再点击两次 ok。 图 14. 内嵌式计算维度建

26、模关系您前面已经使用标准关系建模,设计的元数据可以在 report studio 中用基本关系即席查询和报表。此外,在 ibm cognos bi 中,还可以使用维度建模关系建模 dimensionally modeled relational 简称 dmr。维度建模关系建模指的是一个建模人员为关系型数据源提供的允许进行 olap 风格查询的维度信息,这样就能在 business insight advanced 访问成员函数,进行自主式设计分析和向上、向下钻取。维度建模关系建模通过以下元素定义: 常规维度 regular dimensions 度量维度 measure dimensions

27、范围关系 scope relationships 常规维度l 常规维度表达的是描述性数据,这些数据为度量维度中建模的数据提供上下文。常规维度由一个或多个用户定义的层次结构组成,这些层次结构由层、键、标题和属性组成。常规维度可分解为称为“级别”的信息组。反过来,各级别可以组织为层级。例如,产品维度可以包含组织到单一层级(称为 product)中的级别 product line、product type 和 product。另一个示例是时间维度,包含组织到两个层级中的级别 year、quarter、month、week 和 day。一个层级 yqmd 包含级别 year、quarter、month

28、 和 day,另一个层级 ywd 包含级别 year、week 和 day。最简单的级别定义包含业务键和标题,其中任意一项都引用一个查询项目。级别的实例(或行)定义为该级别的成员。它由成员的唯一名称标识,它是一个五部分的标识符,namespace.dimension.hierarchy.level.query item。如果级别的业务键足以标识级别的每个数据集,则可将级别定义为唯一级别。比如 product 级别的成员是唯一级别,因为它不需要 product type 的定义。未定义为唯一级别的级别类似于非惟一 determinants,比如月份。51. 在 project viewer 窗格

29、,右键点击 model 选择 create,然后点击 namespace,命名为 dimensional view。 52. 右键点击 dimensional view 选择 create,然后点击 regular dimension。 53. 在 available items 窗格,展开 business view 下的 time,拖拽 current_year 到 hierarchies 窗格。 54. 右键选择 hierarchies 窗格最上面的 current_year,点击 rename,输入 time。 55. 把 current_year (all) 重命名为 time (a

30、ll),把最下面的 current_year 重命名为 year。 56. 选择 year 层级,在下方窗口的 role 选择 _businesskey,然后点击 close。 57. 点击下方窗口的 add,命名为 year caption,在 available components 窗口展开 business view 下的 time,把 current_year 拖拽到 expression definition 窗口。编辑表达式为:cast(business view.time.current_year, char(4) 后点击 ok。 58. 在下方窗口选择 year captio

31、n 的 role 为 _membercaption,然后点击 close。 图 15. 层次结构面板59. 从 available items 窗格把 quarter_key 拖拽到 hierarchies 窗格的 year 层下方。重命名为 quarter,然后指定 quarter_key 为 _businesskey 的 role。 60. 仿照 57 和 58 步骤,添加 quarter caption 项,表达式为 cast(business view.time.current_quarter, char(1)。指定 role 为 _membercaption。 61. 从 avail

32、able items 窗格把 month_key 拖拽到 hierarchies 窗格的 quarter 层下方。重命名为 month,然后指定 month_key 为 _businesskey 的 role。 62. 从 available items 窗格把 current_month 拖拽到右下方窗口,选择 _membercaption。 63. 从 available items 窗格把 day_key 拖拽到 hierarchies 窗格的 month 层下方。重命名为 day。注意 day_key 已经是 _businesskey 的 role,这是因为 day_key 是表的主键

33、,属性是 identifier。 64. 从 available items 窗格把 day_date 拖拽到右下方窗口,选择 _membercaption。命名为 day caption。点击 source 编辑定义为 cast(business view.time.day_date, char(10)。点击 ok,因为日期是唯一的,勾选 unique level 选项。 图 16. 时间维度65. 时间维度的排序往往很有用,比如利用 lag 函数查看当前月和上月的数据就需要成员排序。点击 member sort 标签页,在 sorting options 中,勾选 metadata、dat

34、a 和 always (olap compatible)。点击 detect 来检测用在 level sort properties 定义的字段,如图 17 所示。最后点击 ok。 图 17. 成员排序66. 重命名 new dimension 为 time。 67. 您可以参照上面的步骤,在您的模型中添加 products 维度,结果如图 18 所示。在 available items 窗格,展开 business view 下的 products。 o product line 层的 _businesskey 是 product_line_code。 o product line 层的 _

35、membercaption 是 product_line_en。 o product type 层的 _businesskey 是 product_type_key。 o product type 层的 _membercaption 是 product_type_en。 o product name 层的 _businesskey 是 product_key。 o product name 层的 _membercaption 是 product_name。图 18. 产品维度68. 您可以仿照上面的步骤,在您的模型中添加 order methods 维度,结果如图 19 所示。在 availa

36、ble items 窗格,展开 business view 下的 order methods。 o order methods 层的 _businesskey 是 order_method_key。 o order methods 层的 _membercaption 是 order_method_en。 图 19. 订购方法维度l 回页首度量维度度量维度是一个事实逻辑集合,可以实现对关系型数据源进行 olap 风格的查询。度量维度是表达常规维度所描述的数量数据。接下来您将创建度量维度。69. 右键点击 dimensional view,选择 create,然后点击 measure dimens

37、ion。 70. 在 model objects 窗格,展开 business view 下面的 sales fact,按住 shift 选择从 quantity 到 break even point 的所有字段,拖拽到 measures 窗格,如图 20 所示。 图 20. 度量维度71. 点击 ok。重命名 new dimension 为 sales fact。 72. 重复 69 到 71 的步骤,创建 sales target fact 的 measure dimension,选择 business view 下面 sales target fact 的 sales_target。回页

38、首范围关系范围关系仅存在于度量维度和标准维度之间,定义可以用于报表的度量所在的层。在范围关系中没有设置控制查询生成方式的条件,因此前面的关系定义仍然需要,以便生成 sql 语句。如果度量维度和标准维度之间有关系定义的话,范围关系会自动创建,比如您的模型就会自动创建范围关系。73. 双击 dimensional view 命名空间,选择 diagram 标签您可以看到范围关系如图 21 所示。您可以双击关系来编辑范围,接下来用 dimension map 标签来编辑范围关系会更容易。 图 21. 范围关系74. 选择 dimension map 标签,点击 sales target fact,可

39、以看到所有的维度都是高亮显示,这表明目前都在范围内。现在您想让 order methods 不在 sales target fact 范围内,而且 sales target fact 的范围只能是 time 的 month 层和 products 的 product type 层。 75. 点击 month 层,工具栏上点击 set scope 按钮。 76. 点击 product type 层,工具栏上点击 set scope 按钮。 77. 点击 order methods 维度,工具栏上点击 remove scope 按钮。 图 22. 设置 sales target fact 范围创建

40、和管理包模型设计和定义结束以后,需要通过 framework manager 的管理和发布包的功能,将它发布到 cognos 服务器上去,业务人员就能基于发布好的模型,定制我们需要的查询报表和分析报表。在发布之前,您需要在 presentation view 下创建准备发布的命名空间。78. 在 project viewer 窗格,右键 presentation view 点击 create,选择 namespace,重命名为 query,用来做关系型报表。把 presentation view 下的 sales target 和 sales 命名空间拖拽到 query 命名空间下。 79.

41、在 project viewer 窗格,右键 presentation view 点击 create,选择 namespace,重命名为 analysis,用来做维度型分析。接着需要创建维度建模的 star schema grouping 然后放置到 analysis 命名空间下。 80. 右键点击 dimensional view 下的 sales fact,选择 create star schema grouping,如图 23 所示。然后点击 ok。 图 23. 维度建模的 star schema grouping81. 右键点击 dimensional view 下的 sales ta

42、rget fact,选择 create star schema grouping,然后点击 ok。 82. 拖拽新创建的两个命名空间到 analysis 命名空间下。最后的 presentation view 如图 24 所示。 图 24. presentation view83. 在 project viewer 窗格,右键 packages 文件夹,点击 create,选择 package。 84. name 输入 my query,然后点击 next。 85. 清除 model 命名空间的选择,仅仅选择 presentation view 下面的 sales target 和 sales

43、,如图 25 所示。 图 25. 定义 my query 包的内容86. 点击 next,然后设置包函数列表,缺省是包含全部的函数,这里只需要保留 db2,移除其他的。 87. 点击 finish,当提示要启动 publish package wizard,选择 yes。 88. 包缺省是放置在 cognos 公共文件夹,您可以改成 cognos 我的文件夹。去掉 enable model versioning 的选择。点击 next。 89. 在 add security 可以设置包的访问权限和管理权限,然后点击 next。 90. 确保选择了 verify the package before publishing,然后点击 publish。 91. 发布成功后点击 close。 92. 重复步骤 83 到 91 发布 my analysis,这次只选择 sales target fact 和 sales fact 命名空间,如图 26 所示。 图 26. 定义 my analysis 包的内容安全性在 framework manager 中,安全性是一种对 cognos 产品的元数据和数据的权限进行限制的一种方法。对数据的访问进行限制有很多业务原因。 例如,有些数据可能含有绝密数据,只允许特定用户进行查看;可能有各种数据,用户只需要从特定的表或列中检索

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论