Analysis-Services/BestPracticeRules
2021-02-03 16:58:01 +02:00
..
BPARules.json v1.0.0 2021-02-02 15:00:36 +02:00
README.md Update README.md 2021-02-03 16:58:01 +02:00

Purpose

Running this collection of rules inside Tabular Editor's Best Practice Analyzer will inform you of potential issues to fix or improvements to be made with regard to performance optimization and model design.

Feedback

We would love to hear feedback on how this tool has helped your organization. Please email feedback to: pbibestpractice@microsoft.com.

If you find any issues or have any requests for new rules, please submit an issue within this repository. Just prefix the issue with "BPARules" to make it easier to track.

Setup (automated)

Following these steps will automatically load the Best Practice Rules into your local Tabular Editor. Note that this will overwrite the existing BPARules.json file (if you are already have one).

  1. Open Tabular Editor.

  2. Connect to a model.

  3. Run the following code in the Advanced Scripting window.

     System.Net.WebClient w = new System.Net.WebClient();
    
     string userName = System.Environment.UserName;
     string url = "https://raw.githubusercontent.com/microsoft/Analysis-Services/master/BestPracticeRules/BPARules.json";
     string downloadLoc = @"C:\Users\"+userName+@"\AppData\Local\TabularEditor\BPARules.json";
    
     w.DownloadFile(url, downloadLoc);
    
  4. Close and reopen Tabular Editor.

  5. Connect to a model.

  6. Select 'Tools' from the File menu and select 'Best Practice Analyzer'.

  7. Click the Refresh icon (in blue).

Setup (manual)

  1. Open Tabular Editor.
  2. Download the BPARules.json file from GitHub (in this repository).
  3. Within the Start Menu, type %localappdata% and click Enter.
  4. Navigate to the 'TabularEditor' folder.
  5. Copy the rules file (.json) and paste it into the TabularEditor folder.*
  6. Open Tabular Editor and connect to your model.
  7. Select 'Tools' from the File menu and select 'Best Practice Analyzer'.
  8. Click the Refresh icon (in blue).

Notes

  • The following rules require running an additional script before running the Best Practice Analyzer

    • Avoid bi-directional relationships against high-cardinality columns*
    • Large tables should be partitioned*
    • Reduce usage of long-length columns with high cardinality**
    • Split date and time*

    *Use this script as documented here.

    **Use this script in the same fashion as the note above.

    ***Use this script in the same fashion as the note above.

Requirements

Tabular Editor version 2.12.1 or higher