Création de membres calculés d'étendue de requête (MDX)
Si un membre calculé n'est nécessaire que pour une seule requête MDX (Multidimensional Expressions), vous pouvez le définir à l'aide du mot clé WITH. Un membre calculé créé à l'aide du mot clé WITH n'existe plus une fois que l'exécution de la requête est terminée.
Comme l'explique cette rubrique, la syntaxe du mot clé WITH est très souple, et accepte même qu'un membre calculé soit basé sur un autre membre calculé.
Notes
Pour plus d’informations sur les membres calculés, consultez Génération de membres calculés dans MDX (MDX).
Syntaxe du mot clé WITH
Utilisez la syntaxe suivante pour ajouter le mot clé WITH à une instruction MDX SELECT :
[ WITH <SELECT WITH clause> [ , <SELECT WITH clause> ... ] ] SELECT [ * | ( <SELECT query axis clause> [ , <SELECT query axis clause> ... ] ) ]FROM <SELECT subcube clause> [ <SELECT slicer axis clause> ][ <SELECT cell property list clause> ]
<SELECT WITH clause> ::=
( [ CALCULATED ] MEMBER <CREATE MEMBER body clause>) | <CREATE MEMBER body clause> ::= Member_Identifier AS 'MDX_Expression'
[ <CREATE MEMBER property clause> [ , <CREATE MEMBER property clause> ... ] ]
<CREATE MEMBER property clause> ::=
( MemberProperty_Identifier = Scalar_Expression )
Dans la syntaxe du mot clé WITH, la valeur de Member_Identifier
est le nom complet du membre calculé. Ce nom complet comprend la dimension ou le niveau auquel le membre calculé est associé. La valeur MDX_Expression
retourne la valeur du membre calculé après l'évaluation de l'expression. Vous pouvez également, si vous le souhaitez, spécifier les valeurs des propriétés de cellules intrinsèques d'un membre calculé en fournissant le nom de la propriété de cellule dans la valeur MemberProperty_Identifier
et la valeur de la propriété de cellule dans la valeur Scalar_Expression
.
Exemple de mot clé WITH
La requête MDX ci-dessous définit un membre calculé, [Measures].[Special Discount]
, en calculant une remise spéciale basée sur le montant de la remise d'origine.
WITH
MEMBER [Measures].[Special Discount] AS
[Measures].[Discount Amount] * 1.5
SELECT
[Measures].[Special Discount] on COLUMNS,
NON EMPTY [Product].[Product].MEMBERS ON Rows
FROM [Adventure Works]
WHERE [Product].[Category].[Bikes]
Vous pouvez également créer des membres calculés en n'importe quel point d'une hiérarchie. L'exemple de requête MDX ci-dessous définit le membre calculé [BigSeller]
pour un cube Sales hypothétique. Ce membre calculé détermine si un magasin spécifié dispose d'au moins 100 unités de vente dans le domaine des vins et bières. Cependant, la requête crée le membre calculé [BigSeller]
non comme un membre enfant de la dimension [Product]
, mais comme un enfant du membre [Beer and Wine]
.
WITH
MEMBER [Product].[Beer and Wine].[BigSeller] AS
IIf([Product].[Beer and Wine] > 100, "Yes","No")
SELECT
{[Product].[BigSeller]} ON COLUMNS,
Store.[Store Name].Members ON ROWS
FROM Sales
Les membres calculés ne doivent pas forcément dépendre uniquement des membres existants dans un cube. Un membre calculé peut également être basé sur d'autres membres calculés définis dans la même expression MDX. Par exemple, la requête MDX ci-dessous utilise la valeur créée dans le premier membre calculé, [Measures].[Special Discount]
, pour générer la valeur du second membre calculé, [Measures].[Special Discounted Amount]
.
WITH
MEMBER [Measures].[Special Discount] AS
[Measures].[Discount Percentage] * 1.5,
FORMAT_STRING = 'Percent'
MEMBER [Measures].[Special Discounted Amount] AS
[Measures].[Reseller Average Unit Price] * [Measures].[Special Discount],
FORMAT_STRING = 'Currency'
SELECT
{[Measures].[Special Discount], [Measures].[Special Discounted Amount]} on COLUMNS,
NON EMPTY [Product].[Product].MEMBERS ON Rows
FROM [Adventure Works]
WHERE [Product].[Category].[Bikes]
Voir aussi
Guide de référence des fonctions MDX (MDX)
INSTRUCTION SELECT (MDX)
Création de membres calculés au niveau de la session (MDX)