对象命名(Analysis Services - 多维数据)

对象名称、ID 和引用

一般情况下,每个主要对象都包含有以下属性:

  • Name   通常,同级对象的名称在父集合的范围内是唯一的。 例如,两个不同的 Database 对象可能具有相同的 Dimension 名称。 但在这两个 Database 中,Dimension 名称都是唯一的。 有关此规则的例外情况将稍后介绍。 例如,Measure 名称在 Cube 级别需要是唯一的,但在父 MeasureGroup 级别却不需要是唯一的。

  • ID   应用于 Name 属性的唯一性限制也适用于 ID 属性。 此外,ID 属性不可更改。ID 属性是在创建时由用户或应用程序分配的,当然也可由服务器自动分配(当未指定该属性时)。 如果由服务器分配 ID 属性,则服务器会将 ID 属性设置为对象的初始名称。

  • Description

对象引用

对象是通过它们的 ID 属性进行引用的。 ID 属性的命名约定规定,该属性名称以基于目标类型的名称开头,需要添加后缀“ID”,同时还可添加一个提供对象所充当角色的其他信息的前缀。 例如,如果对象为 Cube 中使用的默认度量值, 则其目标类型为 Measure。 您可以向此目标类型名称添加后缀“ID”和前缀“Default”。这样就可生成 ID 属性名称 DefaultMeasureID,如以下代码中所示:

<Cube>

<DefaultMeasureID>Amount</DefaultMeasureID>

<Cube>

 

如果需要包含多个 ID 的限定名称(例如,CubeID 和 MeasureID 都引用另一个 Cube 中的度量值),则可引入外部元素,以包含 ID 元素集。

引用异常

由单个点 (.) 组成的 DataSource 引用 可引用当前 OLAP 服务器的当前数据库。 例如,下面的 XML 片段指向当前 OLAP 服务器实例的当前 Database:

<DataSourceID>.</DataSourceID>

 

对 DataSourceView (DSV) 元素的引用是引用规则的例外情况。 Microsoft .NET Framework 中的 DataSet 对象对 DSV 的架构进行了介绍。 在该架构中,DSV 对象具有 Name,但没有不变的 ID。 因此,对 DSV 对象的引用需要使用 Name 标识机制。 例如,引用 ColumnBinding.TableID 就不包含 ID, 而包含相应表的 Name。

命名规则

对于 Name 和 ID 属性的大小写和空格问题,ASSL 将应用与 DSO 8.0 中所用规则相同的规则:

  • Name 和 ID 的唯一性检查不区分大小写。 因此,同一数据库中不可同时拥有名为“sales”和“Sales”的两个 Cube。

  • Name 或 ID 属性可包含嵌入空格,但却不能有前导空格或尾随空格。 前导空格和尾随空格将会被隐式删除。 此规则既适用于对象的 Name 和 ID,也适用于引用该 Name 和 ID 的元素的值。

以下规则也适用于 Name 和 ID 属性。 这些规则与 DSO 8.0 中的规则类似。

  • 最大字符数为 100。

  • 对标识符的第一个字符没有特殊要求。 第一个字符可为任意有效字符

不可使用以下保留名称:

  • AUX

  • CLOCK$

  • COM1 到 COM9(COM1、COM2、COM3 等)

  • CON

  • LPT1 到 LPT9(LPT1、LPT2、LPT3 等)

  • NUL

  • PRN

  • XML 内的任何字符串的字符都不可为 NULL

下表列出了特定对象的无效字符。

对象

无效字符

Server

此名称必须遵循计算机名称规则。 (IP 地址无效。)

DataSource

: / \ * | ? " () [] {} <>

Level 或 Attribute

. , ; ' ` : / \ * | ? " & % $ ! + = [] {} < >

Dimension 或 Hierarchy

.,, ; ' ` : / \ * | ? " & % $ ! + = () [] {} <,>

所有其他对象

. , ; ' ` : / \ * | ? " & % $ ! + = () [] {} < >

本地化的名称

客户端可见的对象标题(例如,Dimension、层次结构和 Level)可本地化为不同的语言。 通过命令方式定义的对象标题(例如,计算度量值和命名集)作为对象的 MDX 定义的一部分提供。

属性的绑定还允许向不同语言提供属性名称的不同源(例如不同的源列)。

不可本地化对象的名称。