status, city,
product_name, or created_at. Each dimension maps to a column or SQL
expression in your data source.
See the dimensions reference for the full list of
parameters and configuration options.
Defining dimensions
A dimension specifies the SQL expression and its type:Dimension types
Primary keys
Every cube that participates in joins should define aprimary_key dimension. Cube uses primary keys to avoid
fanouts — when rows get duplicated during joins and aggregates are
over-counted. Composite primary keys can be created by concatenating columns:
Time dimensions
Time dimensions are dimensions of thetime type. They enable
grouping by time granularity (year, quarter, month, week, day, hour, minute,
second) and are essential for time-series analysis.
Custom granularities
You can define custom granularities for time dimensions when the built-in ones don’t fit — for example, weeks starting on Sunday or fiscal years:See the following recipes:
- For a custom granularity example.
- For a custom calendar example.
Proxy dimensions
Proxy dimensions reference dimensions from the same cube or other cubes, providing a way to reuse existing definitions and reduce code duplication.Within the same cube
Reference existing dimensions to build derived ones without duplicating SQL:From other cubes
If cubes are joined, you can bring a dimension from one cube into another. Cube generates the necessary joins automatically:Time dimension granularity references
When referencing a time dimension, you can specify a granularity to create a proxy dimension at that specific granularity — including custom granularities:Subquery dimensions
Subquery dimensions reference measures from other cubes, effectively turning an aggregate into a per-row value. This enables nested aggregations — for example, calculating the average of per-customer order counts.order_count subquery dimension computes the order count per user.
The avg_order_count measure then averages those per-user values. Cube
implements this as a correlated subquery via joins for optimal performance.
See the following recipes:
- How to calculate nested aggregates.
- How to calculate filtered aggregates.
Links
Dimensions can declare links — clickable navigation targets that supporting tools (such as Cube Cloud Workbooks) surface next to the dimension’s values.links is a list, so a single dimension can declare any number of
links — they all appear together in the cell menu. Each link points either to
an external URL (url) or to another Cube Cloud dashboard (dashboard,
a drill-in), and its URL is built per row from the dimension’s data. The example
below declares two links on one dimension (an external search and a drill-in).
Dimension
links require Cube v1.6.53 or newer.Parameters
links is a list of link objects. Each link accepts:
| Parameter | Required? | Description |
|---|---|---|
name | Required | Identifier, unique within the dimension. Also used in the synthetic dimension name (see Behavior). |
label | Required | The text shown for the link in the UI. |
url | Either url or dashboard | SQL expression that builds an external URL per row. May reference columns and other dimensions. |
dashboard | Either url or dashboard | The target Cube Cloud dashboard’s slug (a drill-in). Each link sets exactly one of url or dashboard — never both — but different links on the same dimension can mix the two. |
icon | Optional | A Tabler icon name (see Icons). Defaults to a generic link icon. |
target | Optional | Where to open the link: blank (default — new tab) or self (same tab). Applies to external links only — drill-ins always navigate in-app (see Behavior). |
params | Optional | Extra per-row parameters. For url: they are appended as query parameters. For dashboard: they become equality filters on the target dashboard — each key is a member of the target dashboard’s view (a cube path such as orders.status is auto-resolved to the matching view member), and value is the per-row value. |
Example
Icons
icon accepts any name from the Tabler icon set — the
kebab-case name without any prefix, for example brand-google,
external-link, layout-dashboard, or send. Browse and search the available
names at tabler.io/icons. If icon is omitted, a default link
icon is shown.
Setting a dashboard slug
Adashboard: link targets another dashboard by its slug — a short, stable,
human-readable identifier (e.g. orders-detail). The slug is portable across
environments: it is resolved within the current deployment, so the same model
works in development and production without hardcoding dashboard IDs.
To set a slug in Cube Cloud, open the target dashboard, open its options
sidebar, and fill the Slug field (see
Dashboards → Dashboard slug).
Slugs are unique per deployment, and the dashboard: value in your link must
match the slug exactly.
There is no required order. You can write the dashboard: slug in the model
first (it won’t break anything — a link whose slug doesn’t yet resolve is simply
skipped in the cell menu) and set the dashboard’s slug later, or set the
dashboard slug first and reference it from the model afterwards. The link starts
working as soon as both sides use the same slug.
Behavior
- Per-row resolution — each link’s
url(and itsparams) is evaluated for every row, so the destination reflects the clicked cell. Internally a link compiles to a hidden synthetic dimension named<dimension>___link_<name>_urlholding the resolved URL; it is added to the query automatically and is never shown as a column. - Null values — if the source value (and thus the resolved URL) is null for a row, that link is omitted from the menu for that row.
- Where links appear — in Cube Cloud, links surface in the table cell menu on every results table (dashboard and workbook table charts, embedded dashboards, and Explore / SQL results). A left-click on a cell opens the menu listing the dimension’s links, alongside Copy value and, on measures, Drill down.
- Drill-in vs external — a
dashboard:link navigates in-app, in the same tab (Cmd/Ctrl-click opens a new tab), ignoringtarget; aurl:link opens per itstarget(blankby default). - Filters — for
dashboard:links, eachparamsentry becomes an equality filter on the target (thekeyis a view member, thevalueis the per-row value). An unknown or inaccessible target slug is skipped gracefully — the user is notified and no navigation happens.
links reference for the canonical parameter
list.
Hierarchies
Dimensions can be organized into hierarchies to define drill-down paths (e.g., Country → State → City):Next steps
- See the dimensions reference for all parameters
- Learn about measures for aggregated calculations
- Explore custom granularities for fiscal calendars and non-standard time periods