标识符 (MDX)
标识符是 Microsoft SQL Server Analysis Services 对象的名称。 每个 Analysis Services 对象可以有且仅有一个标识符。 这些对象包括多维数据集、维度、层次结构、级别、成员等等。 可以使用对象的标识符在多维表达式 (MDX) 语句中引用对象。
根据命名对象的方式,对象标识符可以是常规标识符,也可以是分隔标识符。
备注
常规标识符和分隔标识符包含的字符数都必须在 1 到 100 之间。
使用常规标识符
常规标识符是符合成为常规标识符的下列格式规则的对象名称。 常规标识符可以和分隔符一起使用,也可以不和分隔符一起使用。
常规标识符的格式规则
第一个字符必须是下列字符之一:
Unicode Standard 2.0 所定义的字母。 除了其他语言的字母字符外,Unicode 定义的字母还包括从 a 到 z 以及从 A 到 Z 的拉丁字符。
下划线 (_)。
后续字符可以是:
Unicode Standard 2.0 所定义的字母。
基本拉丁字符或其他国家/地区字符中的十进制数字。
下划线 (_)。
标识符一定不能是 MDX 保留关键字。 MDX 中的保留关键字区分大小写。 有关详细信息,请参阅 保留关键字(MDX 语法)。
不允许嵌入空格或特殊字符。
常规标识符的示例
在以下 MDX 语句中,标识符 Measures、Product 和 Style 都符合常规标识符的格式规则。 这些常规标识符不需要使用分隔符。
SELECT Measures.MEMBERS ON COLUMNS,
Product.Style.CHILDREN ON ROWS
FROM [Adventure Works]
虽然没有要求,但您也可以将分隔符和常规标识符一起使用。 在以下 MDX 语句中,通过使用方括号正确地分隔了常规标识符 Measures、Product 和 Style。
SELECT [Measures].MEMBERS ON COLUMNS,
[Product].[Style].CHILDREN ON ROWS
FROM [Adventure Works]
使用分隔标识符
不符合成为常规标识符的格式规则的标识符必须始终使用方括号 ([]) 进行分隔。
备注
分隔符仅用于标识符。分隔符不能用于关键字,不管这些关键字在 Analysis Services 中是否标记为保留关键字。
下列情况下需要使用分隔标识符:
当对象的名称或名称中的一部分使用保留关键字时。
建议不要将保留关键字用作对象名称。 从 Analysis Services 的早期版本升级的数据库可能包含这样的标识符:标识符中包含的字在早期版本中不是保留字,而在 SQL Server Analysis Services 中是保留字。 必须先更改对象的标识符,才能使用分隔标识符引用对象。
当对象的名称使用未被列为限定标识符的字符时。
Analysis Services 允许分隔标识符使用当前代码页中的任意字符。 但是,不加选择地在对象名称中使用特殊字符会使 MDX 语句和脚本难以读取和维护。
分隔标识符的格式规则
分隔标识符的主体可以包含当前代码页中的字符(包括分隔符本身)的任意组合。 如果分隔标识符的主体包含分隔符,则需进行特殊处理:
如果标识符的主体只包含左方括号 ([),则无需进行额外处理。
如果标识符的主体包含一个右方括号 (]),则必须指定两个右方括号 (]])。
分隔标识符的示例
在以下假设 MDX 语句中,Sales Volume、Sales Cube 和 select 都是分隔标识符:
-- The [Sales Volume] and [Sales Cube] identifiers contain a space.
SELECT Measures.[Sales Volume]
FROM [Sales Cube]
WHERE Product.[select]
-- The [select] identifier is a reserved keyword.
在下面的这个示例中,对象的名称是 Total Profit [Domestic]。 若要引用此对象,必须使用以下分隔标识符:
[Total Profit [Domestic]]]
请注意,不必更改 Domestic 前面的左方括号来创建分隔标识符。 但是,必须将 Domestic 后面的右方括号替换为两个右方括号。
将标识符分隔为多个部分
使用限定对象名称时,可能需要分隔组成对象名称的多个标识符。 例如,需要分隔以下代码中的 Front Brakes 标识符。
SELECT [Measures].MEMBERS ON COLUMNS,
[Product].[Product].[Front Brakes] ON ROWS
FROM [Adventure Works]
此外,还分隔了上一示例中的 Measures 标识符,以说明分隔多个标识符的情况。