Developed by Ralph Kimball, dimensional modeling is a popular technique used to model data for analytics. At it’s core, dimensional modeling revolves around organizing data into two types of datasets: fact tables and dimension tables. Facts are usually comprised of numerical values that can be aggregated while dimensions hold descriptive attributes of entities/objects. A key tradeoff the dimensional model makes is it denormalizes data (increases data redundancy) in order to speed up queries.

Within dimensional modeling there are a few different schema design patterns: star schema (recommended in most cases), snowflake schema, and galaxy schema.

Dimensional Modeling Advantages

  • Intuitive to understand.
  • Good query performance for analytics.
  • Keeps track of historical changes easily.

Dimensional Modeling Disadvantages

  • Can be complicated to query sometimes.