How to Use Metadata Annotations¶
This guide shows how to annotate dimensions, metrics, facts, and tables with comments, synonyms, and access modifiers in a semantic view definition.
Prerequisites:
A working semantic view with
TABLES,DIMENSIONS, andMETRICS(see Multi-Table Semantic Views)Familiarity with DESCRIBE SEMANTIC VIEW output
Add Comments¶
Comments are human-readable descriptions attached to any entry in the view definition. They appear in DESCRIBE SEMANTIC VIEW output and in the comment column of SHOW commands.
View-level comment¶
Set a comment on the semantic view itself using ALTER:
ALTER SEMANTIC VIEW sales SET COMMENT = 'Revenue and order analytics for the North America region';
Remove a view-level comment:
ALTER SEMANTIC VIEW sales UNSET COMMENT;
Tip
View-level comments appear in the comment column of SHOW SEMANTIC VIEWS and as a SEMANTIC_VIEW object kind row in DESCRIBE SEMANTIC VIEW.
Table-level comment¶
Add a COMMENT clause after the table declaration:
CREATE SEMANTIC VIEW sales AS
TABLES (
o AS orders PRIMARY KEY (id) COMMENT = 'Core order transactions',
c AS customers PRIMARY KEY (id) COMMENT = 'Customer master data'
)
DIMENSIONS (o.region AS o.region)
METRICS (o.revenue AS SUM(o.amount));
Add Synonyms¶
Synonyms are alternative names for an entry. They are informational metadata – they do not affect query resolution, but they appear in DESCRIBE and SHOW output for discoverability.
Add WITH SYNONYMS after the expression (or after the COMMENT clause if both are present):
CREATE SEMANTIC VIEW sales AS
TABLES (
o AS orders PRIMARY KEY (id) COMMENT = 'Order data' WITH SYNONYMS = ('transactions', 'purchases')
)
DIMENSIONS (
o.region AS o.region WITH SYNONYMS = ('sales_region', 'territory')
)
METRICS (
o.revenue AS SUM(o.amount) COMMENT = 'Total sales' WITH SYNONYMS = ('total_sales', 'gmv')
);
Synonyms appear as a JSON array in DESCRIBE SEMANTIC VIEW output (e.g., ["sales_region","territory"]) and in the synonyms column of SHOW SEMANTIC DIMENSIONS.
Set Access Modifiers (PRIVATE / PUBLIC)¶
Metrics and facts support PRIVATE and PUBLIC access modifiers. PUBLIC is the default. PRIVATE items cannot be queried directly – they can only be referenced by derived metric expressions.
CREATE SEMANTIC VIEW sales AS
TABLES (
li AS line_items PRIMARY KEY (id)
)
FACTS (
PRIVATE li.raw_margin AS li.price - li.cost
)
METRICS (
li.total_revenue AS SUM(li.price),
PRIVATE li.total_cost AS SUM(li.cost),
li.total_margin AS SUM(li.raw_margin),
profit AS total_revenue - total_cost
);
In this example:
raw_marginis a private fact – it can be referenced by metrics (liketotal_margin) but cannot be queried viafacts := ['raw_margin'].total_costis a private metric – it can be referenced by derived metrics (likeprofit) but cannot be queried viametrics := ['total_cost'].total_marginandprofitare public (default) and use the private items to compute their values.
Warning
PRIVATE is placed before the table alias (PRIVATE li.total_cost), not after the expression. Dimensions do not support access modifiers.
Inspect Annotations¶
Via DESCRIBE¶
DESCRIBE SEMANTIC VIEW shows annotation properties as additional rows:
DESCRIBE SEMANTIC VIEW sales;
Look for these property rows:
COMMENT– the comment text (conditional, only when set)SYNONYMS– JSON array of synonyms (conditional, only when set)ACCESS_MODIFIER–PUBLICorPRIVATE(always emitted for facts and metrics)NON_ADDITIVE_BY– non-additive dimension list (conditional, only for semi-additive metrics)WINDOW_SPEC– reconstructed OVER clause (conditional, only for window metrics)
Via SHOW commands¶
The SHOW SEMANTIC DIMENSIONS, SHOW SEMANTIC METRICS, and SHOW SEMANTIC FACTS commands include synonyms and comment columns in their output:
SHOW SEMANTIC DIMENSIONS IN sales;
┌───────────────┬─────────────┬────────────────────┬────────────┬────────┬───────────┬──────────────────────────────┬──────────────────────────────────────┐
│ database_name │ schema_name │ semantic_view_name │ table_name │ name │ data_type │ synonyms │ comment │
├───────────────┼─────────────┼────────────────────┼────────────┼────────┼───────────┼──────────────────────────────┼──────────────────────────────────────┤
│ memory │ main │ sales │ orders │ region │ │ ["sales_region","territory"] │ Sales region from shipping address │
└───────────────┴─────────────┴────────────────────┴────────────┴────────┴───────────┴──────────────────────────────┴──────────────────────────────────────┘
Tip
Private items are excluded from SHOW COLUMNS IN SEMANTIC VIEW and from wildcard expansion (alias.*). They only appear in DESCRIBE SEMANTIC VIEW.
Troubleshooting¶
- Comment not appearing in SHOW SEMANTIC VIEWS
Only view-level comments appear in SHOW SEMANTIC VIEWS. Table/dimension/metric/fact comments appear in DESCRIBE SEMANTIC VIEW and in the
commentcolumn of SHOW SEMANTIC DIMENSIONS, SHOW SEMANTIC METRICS, and SHOW SEMANTIC FACTS.- Cannot query a private metric or fact
Private items return an error when queried directly. Use them only in derived metric expressions. To make an item queryable again, recreate the view without the
PRIVATEkeyword.- Synonyms not affecting query resolution
Synonyms are informational metadata only. They do not expand the set of names recognized by semantic_view() or explain_semantic_view(). Use the declared name to query an item.
- COMMENT and WITH SYNONYMS order
When both are present on the same entry,
COMMENTmust come beforeWITH SYNONYMS. The reverse order produces a parse error.
Comments on dimensions, metrics, and facts¶
Add
COMMENTafter the expression on any entry: