OBIEE - Modélisation dimensionnelle
La modélisation dimensionnelle fournit un ensemble de méthodes et de concepts utilisés dans la conception DW. Selon le consultant DW, Ralph Kimball, la modélisation dimensionnelle est une technique de conception de bases de données destinée à prendre en charge les requêtes des utilisateurs finaux dans un entrepôt de données. Il est orienté autour de la compréhensibilité et de la performance. Selon lui, bien que l'ER orienté transaction soit très utile pour la capture de transaction, il devrait être évité pour la livraison à l'utilisateur final.
La modélisation dimensionnelle utilise toujours des faits et des tables de dimension. Les faits sont des valeurs numériques qui peuvent être agrégées et analysées sur les valeurs de fait. Les dimensions définissent les hiérarchies et la description des valeurs de fait.
Tableau des dimensions
La table de dimension stocke les attributs qui décrivent les objets dans une table de faits. Une table de dimension a une clé primaire qui identifie de manière unique chaque ligne de dimension. Cette clé est utilisée pour associer la table Dimension à une table Fact.
Les tables de dimension sont normalement dénormalisées car elles ne sont pas créées pour exécuter des transactions et uniquement utilisées pour analyser les données en détail.
Exemple
Dans le tableau de dimension suivant, la dimension client comprend normalement le nom des clients, l'adresse, l'identifiant client, le sexe, le groupe de revenus, les niveaux d'éducation, etc.
N ° de client | Nom | Le sexe | le revenu | Éducation | Religion |
---|---|---|---|---|---|
1 | Brian Edge | M | 2 | 3 | 4 |
2 | Fred Smith | M | 3 | 5 | 1 |
3 | Sally Jones | F | 1 | sept | 3 |
Tables de faits
La table de faits contient des valeurs numériques appelées mesures. Une table de faits comporte deux types de colonnes: les faits et la clé étrangère pour les tables de dimension.
Les mesures dans le tableau des faits sont de trois types -
Additive - Des mesures qui peuvent être ajoutées dans n'importe quelle dimension.
Non-Additive - Mesures qui ne peuvent être ajoutées dans aucune dimension.
Semi-Additive - Mesures qui peuvent être ajoutées sur certaines dimensions.
Exemple
ID de l'heure | ID produit | N ° de client | Unité vendue |
---|---|---|---|
4 | 17 | 2 | 1 |
8 | 21 | 3 | 2 |
8 | 4 | 1 | 1 |
Ces tables de faits contiennent des clés étrangères pour la dimension temporelle, la dimension produit, la dimension client et l'unité de valeur de mesure vendue.
Supposons qu'une entreprise vend des produits à ses clients. Chaque vente est un fait qui se produit au sein de l'entreprise et la table de faits est utilisée pour enregistrer ces faits.
Les faits courants sont: le nombre d'unités vendues, la marge, le chiffre d'affaires, etc. Le tableau des dimensions répertorie les facteurs tels que le client, le temps, le produit, etc. par lesquels nous voulons analyser les données.
Maintenant, si nous considérons la table de faits et la dimension Client ci-dessus, il y aura également une dimension Produit et temps. Compte tenu de ce tableau de faits et de ces tableaux en trois dimensions, nous pouvons nous poser des questions telles que: Combien de montres ont été vendues à des clients masculins en 2010?
Différence entre le tableau des dimensions et le tableau des faits
La différence fonctionnelle entre les tables de dimension et les tables de faits est que les tables de faits contiennent les données que nous voulons analyser et que les tables de dimension contiennent les informations nécessaires pour nous permettre de les interroger.
Table d'agrégation
La table agrégée contient des données agrégées qui peuvent être calculées à l'aide de différentes fonctions d'agrégation.
Un aggregate function est une fonction dans laquelle les valeurs de plusieurs lignes sont regroupées en entrée sur certains critères pour former une valeur unique de signification ou de mesure plus significative.
Les fonctions d'agrégation courantes incluent -
- Average()
- Count()
- Maximum()
- Median()
- Minimum()
- Mode()
- Sum()
Ces tables agrégées sont utilisées pour l'optimisation des performances afin d'exécuter des requêtes complexes dans un entrepôt de données.
Exemple
Vous enregistrez des tables avec des données agrégées telles que annuelle (1 ligne), trimestrielle (4 lignes), mensuelle (12 lignes) et maintenant vous devez faire une comparaison des données, comme Annuellement, une seule ligne sera traitée. Cependant, dans une table non agrégée, toutes les lignes seront traitées.
MIN | Renvoie la plus petite valeur d'une colonne donnée |
MAX | Renvoie la plus grande valeur d'une colonne donnée |
SOMME | Renvoie la somme des valeurs numériques dans une colonne donnée |
AVG | Renvoie la valeur moyenne d'une colonne donnée |
COMPTER | Renvoie le nombre total de valeurs dans une colonne donnée |
COMPTER (*) | Renvoie le nombre de lignes dans une table |
Sélectionnez Moy (salaire) de l'employé où titre = 'développeur'. Cette déclaration renverra le salaire moyen de tous les employés dont le titre est égal à «Développeur».
Les agrégations peuvent être appliquées au niveau de la base de données. Vous pouvez créer des agrégats et les enregistrer dans des tables d'agrégation de la base de données ou vous pouvez appliquer des agrégats à la volée au niveau du rapport.
Note - Si vous enregistrez des agrégats au niveau de la base de données, cela permet de gagner du temps et d'optimiser les performances.