Mastering DAX Video Course

This is the video course version of the Mastering DAX workshop.
DAX is the native language of Power BI, Power Pivot for Excel, and SSAS Tabular models in Microsoft SQL Server Analysis Services. The training is aimed at users of Power BI, Power Pivot for Excel, and at Analysis Services developers that want to learn and master the DAX language.

The goal of the course is to teach all the features of DAX, providing the knowledge to write formulas for common and advanced business scenarios. The video course is made up of over 15 hours of lectures, plus another 15-20 hours of individual exercises. You can watch the videos at anytime and the system will keep track of your progress. Within the course you can download the material for all the exercises.

Students have access to a private discussion area where they can interact with the instructors asking questions related to the lectures and the exercises.

Collapse allCurriculum

  • Presentation of Mastering DAX 2nd Edition

    • Presentation of Mastering DAX 2nd Edition
      FREE
  • Exercises, labs, slides, and demos

    • Exercises, labs, slides, and demos
      FREE
    • How to download and complete exercises
      FREE
    • Download exercises
    • Download demos
    • Slides of the video course
  • Introduction to DAX

    • Introduction to DAX
      FREE
    • What is DAX?
      FREE
    • DAX data types
      FREE
    • Calculated columns
      FREE
    • Measures
      FREE
    • Aggregation functions
    • Counting values
    • Conditional functions
    • Handling errors
    • Using variables
    • Mathematical functions
    • Relational functions
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 02.10 - Average sales per customer
      • 02.20 - Average delivery time
      • 02.50 - Last update of customer
      • 02.40 - Working days
      • 02.30 - Discount categories
  • Table functions

    • Table functions
      FREE
    • Introduction to table functions
    • Filtering a table
    • Ignoring filters
    • Mixing filters
    • Distinct
    • How many values for a column
    • ALLSELECTED
    • RELATEDTABLE
    • Tables and relationships
    • Tables with one row and one column
    • Table variables
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 03.20 - Percentage of sales
      • 03.10 - Delivery working days
      • 03.40 - Sales of products in the first week
      • 03.30 - Customers with children
  • Evaluation contexts

    • Evaluation contexts
      FREE
    • Introduction to evaluation contexts
    • Filter context
    • Row context
    • Context errors
    • Filtering a table
    • Using RELATED in a row context
    • Ranking by price
    • Evaluation contexts and relationships
    • Filters and relationships
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 04.10 - Nested iterators
      • 04.20 - Customers in North America
      • 05.10 - Create a parameter table
  • The CALCULATE function

    • The CALCULATE function
      FREE
    • CALCULATE
    • CALCULATE examples
    • CALCULATE recap
    • What is a filter context?
    • KEEPFILTERS
    • CALCULATE operators
    • Use one column only in compact syntax
    • Variables and evaluation contexts
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 05.05 - Sales of red and blue products
      • 05.20 - Understanding CALCULATE
      • 05.25 - Sales of blue products
      • 05.15 - Computing percentages
  • Advanced evaluation contexts

    • Advanced evaluation contexts
      FREE
    • CALCULATE modifiers
    • USERELATIONSHIP
    • CROSSFILTER
    • ALL
    • ALLSELECTED
    • KEEPFILTERS
      FREE
    • Context transition
    • Context transition /2
    • Circular dependency
    • CALCULATE execution order
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 05.35 - Correct sales of grey products
      • 05.40 - Best customers
      • 05.45 - Customers buying many products
      • 05.50 - Large sales
      • 05.30 - Percentage of customers
      • 05.55 - Counting spikes
  • Iterators

    • Iterators
      FREE
    • Working with iterators
    • MINX and MAXX
    • Useful iterators
    • RANKX
    • ISINSCOPE
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 07.10 - Ranking customers (static)
      • 07.20 - Ranking customers (dynamic)
      • 07.30 - Date with the highest sales
      • 07.40 - Moving average
  • Building a date table

    • Building a date table
      FREE
    • Introduction to date table
    • Auto Date/Time
    • CALENDARAUTO
    • Mark as date table
    • Using multiple dates
  • Time intelligence in DAX

    • Time intelligence in DAX
      FREE
    • What is time intelligence?
      FREE
    • Time intelligence functions
      FREE
    • DATEADD
    • DATESINPERIOD
    • Running total
    • Mixing time intelligence functions
    • Semi-additive measures
    • Calculations over weeks
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 08.10 - Running total
      • 08.20 - Comparison YOY%
      • 08.30 - Sales in first three months
      • 08.40 - Semi-additive calculations
  • Hierarchies in DAX

    • Hierarchies in DAX
      FREE
    • What are hierarchies?
    • FILTER and CROSSFILTER
    • Percentages over hierarchies
    • Parent-child hierarchies
  • Querying with DAX

    • Querying with DAX
      FREE
    • Working with tables and queries
    • EVALUATE
    • CALCULATETABLE
    • SELECTCOLUMNS
    • SUMMARIZE
    • SUMMARIZECOLUMNS
    • CROSSJOIN
    • TOPN and GENERATE
    • ROW and DATATABLE
    • Tables and relationships
    • UNION, INTERSECT, and EXCEPT
    • GROUPBY
    • Query measures
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 13.10 - Sales by year
      • 13.20 - Filtering and grouping sales
      • 13.30 - Using TOPN and GENERATE
      • 13.40 - Sales to top customers
      • 13.50 - Sales of top three colors
  • Data lineage and TREATAS

    • Data lineage and TREATAS
      FREE
    • What is data lineage?
    • TREATAS
  • Expanded tables

    • Expanded tables
      FREE
    • Filters are tables
    • Difference between base tables and expanded tables
    • Filtering a column
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 14.10 - Distinct count of countries
      • 14.20 - Sales quantity greater than two
  • Arbitrarily shaped filters

    • Arbitrarily shaped filters
      FREE
    • What are arbitrarily shaped filters?
    • Example of an arbitrarily shaped filter
  • ALLSELECTED and shadow filter contexts

    • ALLSELECTED and shadow filter contexts
      FREE
    • ALLSELECTED
    • Shadow filter contexts
  • Segmentation

    • Segmentation
      FREE
    • Static segmentation
    • Circular dependency in calculated tables
    • Dynamic segmentation
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 15.10 - Static segmentation
  • Many-to-many relationships

    • Many-to-many relationships
      FREE
    • How to handle many-to-many relationships
    • Bidirectional filtering
    • Expanded table filtering
    • Comparison of the different techniques
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 15.30 - Many-to-many relationships
  • Ambiguity and bidirectional filters

    • Ambiguity and bidirectional filters
      FREE
    • Understanding ambiguity
      FREE
  • Relationships at different granularities

    • Relationships at different granularities
      FREE
    • Working at different granularity
    • Using TREATAS
    • Calculated tables to slice dimensions
    • Leveraging weak relationships
    • Scenario recap
    • Checking granularity in the report
    • Hiding or reallocating
  • Additional exercises

    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 14.30 - Same product sales
      • 14.40 - Commentary on report
      • 15.20 - New customers
  • Calculation groups

    • Calculation groups
      FREE
    • Introducing calculation groups
      FREE
    • Basic measures
    • Calculation items are patterns
    • Creating calculation groups
    • Changing the format string
    • Excluding specific measures
    • Using calculation items in DAX
    • Calculation item application
    • Calculation items on complex expressions
    • Multiple calculation groups in a report
    • Understanding precedence in calculation groups
    • Reusing calculation items
    • Recursion and best practices
    • Exercises
      FREE
    • Exercises solutions
      Added Nov 20, 2020

      • Exercises solutions
      • 09.10 - Time calculations
      • 09.20 - Multiple calculation groups
      • 09.30 - Sold versus delivered
      • 09.40 - Min, Max and Avg calculation group
      • 09.50 - Top and bottom products
Student Rating
4.9
536 ratings
Student Reviews (288)
  • Alexander Feygin (Jan 24, 2020)

    Definetely this's the example of how on-line video course shoud be made. It's up-to-date, includes professianally made support materials (demo files, slides, exercise book), covers deep theoretical nuances of dax logic (which is the foudation of your ability to write and uderstand how code works). At the same time, there's a huge amount of sophisticated exercises (especially advanced section) that helps you to get practical skills. Also, thanks a lot for your blog and tools like dax formatter. Your blog posts should become the next step in learning all the technics and nuances of dax language and proper data modeling.

  • Andy Stepas (Jan 21, 2020)

    I love this video course!. Excellent and simple explanations of the most used DAX functions and are available at any time you need them. Thanks Marco and Alberto, keep going doing with this kind of courses.

  • Ryan Park (Jan 15, 2020)

    This course is the most comprehensive course I could find regarding DAX. Here a couple of opinions. There only needs to be 1 instructor per section and the instructor does not need to be in the video. It would be nice to see the slides and the computer screen without the instructor obstructing the view. You would also benefit from not having to rely on the other instructor to fit the screen or go back to a function, etc. It feels like you are stepping over each other a lot. I feel like you are trying to make the questions seem natural but it doesn't work. Outside of that. Excellent course.

  • Swapnil Sangle (Dec 26, 2019)

    Hi Marco , Alberto. The course is absolutely amazing. After going through this course, I bought your "Data Modelling" course. Great content, excellent delivery. Just one suggestion, Is it possible to provide a data or data source from a different industry may be IT, along with list of exercises to solve. This can act as a project and also help us to test our understanding. Thanks, Swapnil

    • The reason why we use always the same sample data (Contoso) is because this allows the reader to focus on the exercise/module topics rather than the details of the implementation. This is especially true for the DAX course. For Data Modeling we already introduced different data models in order to present and to solve specific modeling problems. However, in those cases the amount of data included is very limited. The reason is that sample data must satisfy a number of requirements and not create any issue related to privacy, NDA, and advertising. The Contoso sample database is a huge investment that Microsoft made 10-15 years ago. In such a database, all the names have been cleared for publishing. Similar investments are certainly not possible for a single video course. Therefore, while we agree that adding specific industry-related models would be very useful, it is unlikely to happen - at least considering a data model populated with reasonable data, like Contoso and Adventure Works.
      Reply by SQLBI (Dec 26, 2019)
  • Andy Stepas (Dec 1, 2019)

    I love this course!. Excellent explanation of DAX functions and I can review every time I need to remember some function. Thanks Marco and Alberto for dedicating your time doing this course paying attention to every detail.

  • Fabio Verga (Nov 19, 2019)

    Great Course. Very interesting and with lots of useful examples

  • Genadiy Tsvetkov (Nov 18, 2019)

    Outstanding! an incredibly full and thorough course. Thanks Marco and Alberto for creating such a valuable product for those who seek to expand knowledge in DAX.

  • Udit Chatterjee (Nov 8, 2019)

    The best platform to learn and implement DAX. Thanks for all the awesome videos.

  • STANISLAV GODIN (Nov 5, 2019)

    This is very good class and is very involved. I will have to re-watch some of the parts of the class and re-do the exercises. The main problem with DAX for anyone who is coming from T-SQL experience is that the principles to query the data are very different. You need to reconfigure your brain.

  • Thomas Rice, PMP (Nov 3, 2019)

    Great course! Highly recommended and sharing my experience on LinkedIn. I found the course challenging and insightful and while I didn't get the format right on many exercises the first try, I did understand the concepts; so I felt the delivery of training was impeccable. I passed exam 70-779 Excel and this course will help me secure a passing score in 70-778 PowerBI. I fully intend to continue my studies here with the next level courses. Thanks again! Tom

  • Paulo Rocha (Nov 2, 2019)

    They did it again. Excellent work. I decided to do the 2nd Edition in full and I'm more than happy that I did it. New approaches, new insights, new DAX functions! Marco and Alberto are really what is excellence in DAX and teaching! Also happy for the extended period to enjoy the new content. Thanks again Maestros!

  • Alison Sissins (Nov 1, 2019)

    Very thorough in depth course. It can be confusing with all the scenarios and solutions but this is what it's like using DAX for real.

  • Stefan Feldmann (Oct 27, 2019)

    Hello, Alberto and Marco. Thank you very much for this excellent course, which teaches complex topics in an understandable and plausible way. To be honest, the course is not easy and requires concentration and discipline. Many questions and traps have disappeared and laid a good foundation and understanding for future reports. Now it will be a matter of practice and experience to consolidate this knowledge. The examples, slides, but also the book "The Definitive Guide to DAX (2nd Edition)" serve as an optimal reference to me. I can only explicitly recommend this course to all those who want to practice professional reporting in combination with DAX. Best regards Stefan Feldmann

  • Anicet TCHOKOTHE (Oct 17, 2019)

    Very good Course, presentation, explanations. Thanks Marco and Alberto

  • Yves Goux (Sep 24, 2019)

    very good learning course

Would you prefer a classroom course?

This video course is based on a classroom course we teach all around the world. If you prefer a classroom learning experience, take a look at the dates below for a list of our upcoming classroom courses!
 Seattle, WA, US May 6-8, 2024
Seattle
 Hamburg, DE May 14-16, 2024
Hamburg
 Copenhagen, DK May 22-24, 2024
Copenhagen
 Chicago, IL, US Jun 25-27, 2024
Chicago
 Melbourne, VIC, AU Aug 6-8, 2024
Melbourne
 Sydney, NSW, AU Aug 12-14, 2024
Sydney
 Brisbane, QLD, AU Aug 19-21, 2024
Brisbane