Partager via


Calculs

Un calcul est une expression mdX (Multidimensional Expressions) ou un script utilisé pour définir un membre calculé, un jeu nommé ou une affectation délimitée dans un cube dans Microsoft SQL Server Analysis Services. Les calculs vous permettent d’ajouter des objets qui ne sont pas définis par les données du cube, mais par des expressions qui peuvent référencer d’autres parties du cube, d’autres cubes ou même des informations en dehors de la base de données Analysis Services. Les calculs vous permettent d'étendre les capacités d'un cube, en renforçant la flexibilité et la puissance des applications de décisionnel. Pour plus d’informations sur les calculs de script, consultez Présentation du script MDX dans Microsoft SQL Server 2005. Pour plus d’informations sur les problèmes de performances liés aux requêtes et calculs MDX, consultez le Guide des performances de SQL Server 2005 Analysis Services.

Membres calculés

Un membre calculé est un membre dont la valeur est calculée au moment de l'exécution en utilisant une expression MDX (Multidimensional Expressions) que vous spécifiez lorsque vous définissez le membre calculé. Un membre calculé est disponible pour les applications de décisionnel comme n'importe quel autre membre. Les membres calculés n'augmentent pas la taille du cube, car seules les définitions sont stockées dans le cube ; les valeurs sont calculées dans la mémoire lorsqu'il faut répondre à une requête.

Les membres calculés peuvent être définis pour n'importe quelle dimension, y compris la dimension de mesures. Les membres calculés créés sur la dimension de mesures sont appelés mesures calculées.

Bien que les membres calculés reposent généralement sur les données qui existent déjà dans le cube, vous pouvez créer des expressions complexes en combinant les données avec des opérateurs arithmétiques, des nombres et des fonctions. Vous pouvez également utiliser des fonctions MDX, telles que LookupCube, pour accéder aux données dans d’autres cubes de la base de données Analysis Services. Analysis Services inclut des bibliothèques de fonctions Visual Studio standardisées et vous pouvez utiliser des procédures stockées pour récupérer des données à partir de sources autres que la base de données Analysis Services actuelle. Pour plus d’informations sur les procédures stockées, consultez Définition des procédures stockées.

Supposons, par exemple, que les cadres d'une société de transport veuillent déterminer les types de cargaisons les plus rentables à transporter, en fonction du bénéfice par unité de volume. Ils utilisent un cube Shipments qui contient les dimensions Cargo, Fleet et Time et les mesures Price_to_Ship, Cost_to_Ship et Volume_in_Cubic_Meters ; cependant, ce cube ne contient pas de mesure de rentabilité. Vous pouvez créer un membre calculé correspondant à une mesure appelée Profit_per_Cubic_Meter dans le cube en combinant les mesures existantes dans l'expression suivante :

([Measures].[Price_to_Ship] - [Measures].[Cost_to_Ship]) /  
[Measures].[Volume_in_Cubic_Meters]  

Une fois que vous avez créé le membre calculé, Profit_per_Cubic_Meter s'affichera avec les autres mesures au prochain affichage du cube Shipments.

Pour créer des membres calculés, utilisez l’onglet Calculsdans le Concepteur de cube. Pour plus d’informations, consultez Créer des membres calculés

Jeux nommés

Un jeu nommé est une expression contenant une instruction MDX CREATE SET qui retourne un jeu. L’expression MDX est enregistrée dans le cadre de la définition d’un cube dans Microsoft SQL Server Analysis Services. Un jeu nommé est créé afin d'être réutilisé dans les requêtes MDX (Multidimensional Expressions). Un jeu nommé permet aux utilisateurs professionnels de simplifier leurs requêtes et d'utiliser un nom de jeu au lieu d'une expression de jeu pour les expressions de jeu complexes et fréquemment employées. Rubrique connexe : Créer des jeux nommés

Commandes de script

Une commande de script est un script MDX, intégré dans la définition du cube. Les commandes de script permettent d'effectuer quasiment toute action prise en charge par MDX sur un cube, telle que l'attribution d'étendue d'un calcul à une seule partie du cube. Dans SQL Server Analysis Services, les scripts MDX peuvent s’appliquer à l’ensemble du cube ou à des sections spécifiques du cube, à des points spécifiques tout au long de l’exécution du script. La commande de script par défaut, l'instruction CALCULATE, remplit les cellules du cube avec des données agrégées en fonction de l'étendue par défaut.

L'étendue par défaut est le cube tout entier, mais vous pouvez définir une étendue plus limitée - que l'on appelle sous-cube - puis appliquer un script MDX seulement à cet espace particulier du cube. L'instruction SCOPE définit l'étendue de toutes les instructions et expressions MDX ultérieures dans le script de calcul jusqu'à ce que l'étendue soit arrêtée ou redéfinie. L'instruction THIS est ensuite utilisée pour appliquer une expression MDX à l'étendue actuelle. Vous pouvez utiliser l'instruction BACK_COLOR pour spécifier une couleur d'arrière-plan de cellule pour les cellules de l'étendue actuelle, afin de faciliter le débogage.

Par exemple, vous pouvez utiliser une commande de script pour attribuer des quotas de ventes à des employés en fonction du temps et des territoires de ventes en utilisant comme références les valeurs pondérées des ventes dans une période antérieure.

Voir aussi

Calculs dans les modèles multidimensionnels