The ultimate Microsoft Fabric, Power BI, Azure AI, and SQL learning event: Join us in Stockholm, September 24-27, 2024.
Save €200 with code MSCUST on top of early bird pricing!
Find everything you need to get certified on Fabric—skills challenges, live sessions, exam prep, role guidance, and more. Get started
Hello,
Just to provide an overview before proceeding further, we are a BI team who have recently switched to Tabular Editor as our main Dev tool for PBI model development.
While browing the capabilities available on TE3, we came across this article about the IsAvailableforMDX property :
https://blog.crossjoin.co.uk/2018/07/02/isavailableinmdx-ssas-tabular/
This property is enabled by default on PBI Tabular models which in turn allows automatic creation on Attribute Heirarchies on the tables/columns.
We tested this on one of our test data models by disabling this property on all columns of 4 Dim tables and 1 Fact table. The results are below:
Before:
After:
As you can see, disabling this property reduced the over table and column size of these 4 tables.
The 'Hier Size' (size of heirarchy) went down to 0 on all these tables that helped bring down the overall table and column size for all 5 tables. This is understandable as we had disabled the IsAvailableforMDX, eventually avoiding the model create any attribute heirarchies.
But as we can also see, the 'Dict Size' (size of Data Dictionary) also came down for all tables (esp. for the Dim tables), which helped in bringing down overall table/column size. We have been trying to understand how disabling the IsAvailableforMDX property brings down the DD size as it doesn't correlate to the heirarchy creation.
Can anyone advise on how and why the Data Dictionary size reduced and what actually changed? Please let us know if you need more details.
Solved! Go to Solution.
@Koushikrish
This setting will impact Excel connections to the Power BI Analysis Service Tabular model. Excel relies on MDX to generate query against the DataSet. If this is set to False, excel users will not be able to select the column in a pivot. It is the equivalent to hiding a column, but it will also remove the search index hence the size reduction. It is recommended to use for Measure columns (i.e. things you will aggregate by; not group by).
@marcorusso explain this in the video round the 40 min mark. Optimizing Power BI model size and memory by using DAX Studio metrics and VertiPaq Analyzer by Marco...
The dictionary size shouldn't change, but you should make sure you did your test in the same conditions. FOr example, you might have run a full refresh after changing the IsAvailableInMDX property and this removes any unused entry from the dictionary - which could include unused entries in other conditions, such as (but not limited to) an incremental refresh.
Try to run a full refresh of the whole database with the two settings and then compare what you see at that point.
If you would see a significant difference in the dictionary at that point, it would be strange and deserve more investigation.
You can rebuild the dictionary by using Defragment instead of Refresh - Calculate does not reset the dictionary.
See RefreshType Enum (Microsoft.AnalysisServices.Tabular) | Microsoft Docs
The dictionary size shouldn't change, but you should make sure you did your test in the same conditions. FOr example, you might have run a full refresh after changing the IsAvailableInMDX property and this removes any unused entry from the dictionary - which could include unused entries in other conditions, such as (but not limited to) an incremental refresh.
Try to run a full refresh of the whole database with the two settings and then compare what you see at that point.
If you would see a significant difference in the dictionary at that point, it would be strange and deserve more investigation.
Hi Marco,
Thanks for the reply. I am doing the following steps now:
1. Set the property back to True.
2. Refresh the model.
3. Run Vertipaq analyzer.
I will repeat the same with the property set to False and compare the results.
Regarding the refresh : Does it actually have to be a 'Full Refresh' of the model (it takes over 3 hours for this entire model to refresh)? Considering that we are just going to recalculate the dictionary after the updates wouldn't a 'Calculate' refresh of the model suffice? Please advise.
@Koushikrish
This setting will impact Excel connections to the Power BI Analysis Service Tabular model. Excel relies on MDX to generate query against the DataSet. If this is set to False, excel users will not be able to select the column in a pivot. It is the equivalent to hiding a column, but it will also remove the search index hence the size reduction. It is recommended to use for Measure columns (i.e. things you will aggregate by; not group by).
@marcorusso explain this in the video round the 40 min mark. Optimizing Power BI model size and memory by using DAX Studio metrics and VertiPaq Analyzer by Marco...
Join the community in Stockholm for expert Microsoft Fabric learning including a very exciting keynote from Arun Ulag, Corporate Vice President, Azure Data.
Check out the August 2024 Power BI update to learn about new features.
User | Count |
---|---|
50 | |
26 | |
14 | |
14 | |
12 |
User | Count |
---|---|
107 | |
39 | |
24 | |
23 | |
19 |