A level-based measure is a column whose values are always calculated to a specific level of aggregation. It is useful to calculate share measures. A company wants to calculate Revenue share of each product, First you need to calculate Product Total (Revenue is aggregated to Product Total).
Creating Level-Based Measures
- In the BMM layer, right-click the F1 Revenue table and select New Object > Logical Column to open the Logical Column dialog box.
- On the General tab, enter Product Total Revenue in the Name field.
- Click the Column Source tab.
- Select Derived from existing columns using an expression.
- Open the Expression Builder.
- In the Expression Builder, add Logical Tables > F1 Revenue > Revenue to the expression. Recall that the Revenue column already has a default aggregation rule of Sum.
- Click OK to close Expression Builder.
- Click the Levels tab.
- For the H2 Product logical dimension, select Product Total from the Logical Level drop-down list to specify that this measure should be calculated at the grand total level in the product hierarchy.
- Click OK to close the Logical Column dialog box. The Product Total Revenue measure appears in the Product Total level of the H2 Product logical dimension and the F1 Revenue logical fact table.
- Repeat the steps to create a second level-based measure:
Name
|
Logical Dimension
|
Logical Level
|
Product Type Revenue
|
H2 Product
|
Product Type
|
- Expose the new columns to users by dragging Product Total Revenue and Product Type Revenue to the Base Facts presentation table in the Sample Sales subject area in the Presentation layer. You can drag the columns from either the H2 Product logical dimension or the F1 Revenue logical table.
Creating a Share Measure
- In the BMM layer, right-click the F1 Revenue table and select New Object > Logical Column to open the Logical Column dialog box.
- On the General tab, name the logical column Product Share.
- On the Column Source tab, select "Derived from existing columns using an expression".
- Open the Expression Builder.
- In the Expression Builder, Select Functions > Mathematic Functions > Round.
- Click Insert selected item. The function appears in the edit box.
- Click Source Number in the formula.
- Enter 100* followed by a space.
- Insert Logical Tables > F1 Revenue > Revenue.
- Using the toolbar, click the Division button. Another set of angle brackets appears, <<expr>>.
- Click <<expression>>.
- Insert Logical Tables > F1 Revenue > Product Total Revenue. Recall that this is the total measure for the hierarchy.
- Click between the last set of angle brackets, <<Digits>>, and enter 1. This represents the number of digits of precision with which to round the integer.
- Check your work:
Round(100* "Sample Sales"."F1 Revenue"."Revenue" / "Sample Sales"."F1 Revenue"."Product Total Revenue" , 1)
This share measure will allow you to run an analysis that shows how revenue of a specific product compares to total revenue for all products.
- Click OK to close the Expression Builder. The formula is visible in the Logical Column dialog box.
- Click OK to close the Logical Column dialog box. The Product Share logical column is added to the business model.
- Add the Product Share measure to the Base Facts presentation table.
- Save the repository. Check consistency. You should receive the following message.
If there are consistency errors or warnings, correct them before you proceed.
- Close the repository.
Testing Your Work
- Return to Oracle Enterprise Manager and load the BISAMPLE repository.
- Return to Oracle BI, which should still be open, and sign in.
- Create the following analysis to test the level-based and share measures.
Products.Product
Base Facts.Revenue
Base Facts.Product Type Revenue
Base Facts.Product Share
Base Facts.Revenue
Base Facts.Product Type Revenue
Base Facts.Product Share
- For the Product Share column, select Column Properties.
- On the Data Format tab, select Override Default Data Format.
- Change Treat Numbers As to Percentage and set Decimal Places to 2. Deselect Use 1000's separator.
- Click OK to close the Column Properties dialog box.
- Sort Product Share in descending order.
- Click Results. Notice that Product Type Revenue returns dollars grouped by Type even though the query is at a different level than Type; Product in this example. Product Share shows the percent of total revenue for each product sorted in descending order.
No comments:
Post a Comment