| name | developing-in-lightdash |
| description | Use when working with Lightdash YAML files, dbt models with Lightdash metadata, the lightdash CLI (deploy, upload, download, preview, lint, sql, set-warehouse), or creating/editing charts, dashboards, metrics, and dimensions as code |
Developing in Lightdash
Build and deploy Lightdash analytics projects. This skill covers the semantic layer (metrics, dimensions, joins) and content (charts, dashboards).
When to Use
- Working with Lightdash YAML files (charts, dashboards, models as code)
- Using the
lightdash CLI (deploy, upload, download, preview, lint, sql)
- Defining metrics, dimensions, joins, or tables in dbt or pure Lightdash projects
- Creating or editing charts and dashboards as code
Don't use for: Developing the Lightdash application itself (use the codebase CLAUDE.md), general dbt work without Lightdash metadata, or raw SQL unrelated to Lightdash models.
What You Can Do
| Task | Commands | References |
|---|
| Explore data warehouse | lightdash sql to execute raw sql, read .csv results | CLI Reference |
| Define metrics & dimensions | Edit dbt YAML or Lightdash YAML | Metrics, Dimensions |
| Create charts | lightdash download, edit YAML, lightdash upload | Chart Types |
| Add period comparisons | Add PoP additional metrics to chart YAML | Period over Period |
| Build dashboards | lightdash download, edit YAML, lightdash upload | Dashboard Reference |
| Lint yaml files | lightdash lint | CLI Reference |
| Set warehouse connection | lightdash set-warehouse from profiles.yml | CLI Reference |
| Deploy changes | lightdash deploy (semantic layer), lightdash upload (content) | CLI Reference |
| Test changes | lightdash preview | Workflows |
Common Mistakes
| Mistake | Consequence | Prevention |
|---|
| Guessing filter values | Case mismatches ('Payment' vs 'payment') cause charts to silently return no data | Always run lightdash sql "SELECT DISTINCT column FROM table LIMIT 50" -o values.csv and use exact values |
| Not updating dashboard tiles after renaming a chart | Dashboard tile still shows old title — title and chartName are independent overrides that do NOT auto-update | Download the dashboard, find tiles with matching chartSlug, update title and chartName to match |
| Including unused dimensions in metricQuery | "Results may be incorrect" warning — extra dimensions change SQL grouping and produce wrong numbers | Every dimension in metricQuery.dimensions must appear in the chart config. For cartesian: layout.xField, layout.yField, or pivotConfig.columns |
| Unsorted YAML keys | lightdash upload warns "unsorted YAML keys" and diffs become noisy | Always sort keys alphabetically at every nesting level — the CLI writes with sortKeys: true |
| Deploying to wrong project | Overwrites production content | Always run lightdash config get-project before deploying |
Missing contentType field | Content type can't be determined without relying on directory structure | Always include contentType: chart, contentType: dashboard, or contentType: sql_chart at the top level |
Before You Start
Check Your Target Project
Always verify which project you're deploying to. Deploying to the wrong project can overwrite production content.
lightdash config get-project
lightdash config list-projects
lightdash config set-project --name "My Project"
Detect Your Project Type
The YAML syntax differs significantly between project types.
| Type | Detection | Key Difference |
|---|
| dbt Project | Has dbt_project.yml | Metadata nested under meta: |
| dbt Fusion / dbt 1.10+ | Has dbt_project.yml, uses dbt Fusion or dbt >= 1.10 | Metadata nested under config: meta: |
| Pure Lightdash | Has lightdash.config.yml, no dbt | Top-level properties |
ls dbt_project.yml 2>/dev/null && echo "dbt project" || echo "Not dbt"
ls lightdash.config.yml 2>/dev/null && echo "Pure Lightdash" || echo "Not pure Lightdash"
dbt Fusion / dbt 1.10+: Lightdash metadata must be nested under config: meta: instead of meta:. The properties are identical — only the nesting changes. Example:
models:
- name: orders
config:
meta:
metrics:
total_revenue:
type: sum
sql: "${TABLE}.amount"
Syntax Comparison
dbt YAML (metadata under meta:):
models:
- name: orders
meta:
metrics:
total_revenue:
type: sum
sql: "${TABLE}.amount"
columns:
- name: status
meta:
dimension:
type: string
Pure Lightdash YAML (top-level):
type: model
name: orders
sql_from: 'DB.SCHEMA.ORDERS'
metrics:
total_revenue:
type: sum
sql: ${TABLE}.amount
dimensions:
- name: status
sql: ${TABLE}.STATUS
type: string
Setting Up Warehouse Connection
If the project needs a different warehouse connection (e.g., switching from Postgres to BigQuery), update it from your profiles.yml:
lightdash set-warehouse --project-dir ./dbt --profiles-dir ./profiles --assume-yes
This reads credentials from profiles.yml, updates the warehouse connection on the currently selected project, and triggers a recompile. Run this before lightdash deploy.
To target a specific project:
lightdash set-warehouse --project-dir ./dbt --profiles-dir ./profiles --project <uuid> --assume-yes
Core Workflows
Verify Filter Values Before Using Them
CRITICAL: Never guess filter values. Case mismatches (e.g., 'Payment' vs 'payment') cause charts to silently return no data.
Before writing any string filter, query actual values from the warehouse:
lightdash sql "SELECT DISTINCT category FROM payments LIMIT 50" -o category_values.csv
Read the CSV and use the exact values in your filter YAML. This applies to all equals/notEquals filters with string values — in charts and dashboards.
Editing Metrics & Dimensions
- Find the model YAML file (dbt:
models/*.yml, pure Lightdash: lightdash/models/*.yml)
- Edit metrics/dimensions using the appropriate syntax for your project type
- Validate:
lightdash lint (pure Lightdash) or dbt compile (dbt projects)
- Deploy:
lightdash deploy
See Metrics Reference and Dimensions Reference for configuration options.
Editing Charts
- Download:
lightdash download --charts chart-slug
- Edit the YAML file in
lightdash/ directory
- Verify filter values: If you added or changed filters, use
lightdash sql to check actual column values (see Common Mistakes)
- Update dashboard tiles: If you changed the chart's name or purpose, download any dashboards that reference it and update their tile
title and chartName properties to match (see Common Mistakes)
- Lint:
lightdash lint to validate before uploading
- Upload:
lightdash upload --charts chart-slug (and any modified dashboards)
Dashboard tiles have their own titles. A saved_chart tile's title and chartName properties are independent overrides — they do NOT auto-update when you rename the chart. If you change a chart from "Total Revenue" to "Gross Profit" but don't update the dashboard tile, the dashboard will still display "Total Revenue". Always download the dashboard, find tiles with matching chartSlug, and update their title and chartName to match.
tiles:
- type: saved_chart
properties:
chartSlug: total-revenue-kpi
title: "Gross Profit"
chartName: "Gross Profit"
Editing Dashboards
- Download:
lightdash download --dashboards dashboard-slug
- Edit the YAML file in
lightdash/ directory
- Verify filter values: If you added or changed filters, use
lightdash sql to check actual column values (see Common Mistakes)
- Lint:
lightdash lint to validate before uploading
- Upload:
lightdash upload --dashboards dashboard-slug
Creating New Content
Charts and dashboards are typically created in the UI first, then managed as code:
- Create in UI
lightdash download to pull as YAML
- Edit and version control
lightdash lint to validate before uploading
lightdash upload to sync changes
Testing with Preview
For larger changes, test in isolation:
lightdash preview --name "my-feature"
lightdash stop-preview --name "my-feature"
CLI Quick Reference
| Command | Purpose |
|---|
lightdash deploy | Sync semantic layer (metrics, dimensions) |
lightdash upload | Upload charts/dashboards |
lightdash download | Download charts/dashboards as YAML |
lightdash lint | Validate YAML locally |
lightdash preview | Create temporary test project |
lightdash sql "..." -o file.csv | Run SQL queries against warehouse |
lightdash run-chart -p chart.yml | Execute chart YAML query against warehouse |
See CLI Reference for full command documentation.
Semantic Layer
The semantic layer defines your data model. See individual references for full configuration:
- Tables Reference — queryable entities, labels, joins
- Metrics Reference — aggregated calculations (
count, sum, average, min, max, number, etc.)
- Dimensions Reference — attributes for grouping/filtering (
string, number, boolean, date, timestamp)
- Joins Reference — cross-table relationships
Chart Types
All charts share a common base structure:
chartConfig:
config: {}
type: <type>
contentType: chart
dashboardSlug: my-dashboard
metricQuery:
dimensions:
- my_explore_category
exploreName: my_explore
filters: {}
limit: 500
metrics:
- my_explore_total_sales
sorts: []
name: "Chart Name"
slug: unique-chart-slug
spaceSlug: target-space
tableConfig:
columnOrder: []
tableName: my_explore
version: 1
Key ordering: All YAML keys must be sorted alphabetically at every nesting level. The CLI writes files with sortKeys: true and warns on upload if keys are unsorted. When writing or editing YAML by hand, keep keys in alphabetical order to avoid warnings and noisy diffs.
Chart scoping: Use spaceSlug only for shared charts. Add dashboardSlug to scope a chart to a specific dashboard (it won't appear in the space).
Choosing the Right Chart Type
| Data Pattern | Recommended Chart | Why |
|---|
| Trends over time | Line or area (cartesian) | Shows continuous change with time on X-axis |
| Category comparisons | Bar (cartesian) | Easy visual comparison between discrete categories |
| Part-of-whole relationships | pie or treemap | Shows proportions summing to 100% |
| Single KPI metric | big_number | Focuses attention on one important value |
| Conversion stages | funnel | Visualizes drop-off between sequential steps |
| Progress toward target | gauge | Shows current value relative to goal |
| Geographic data | map | Plots data points or regions on a map |
| Detailed records | table | Displays raw data with sorting and formatting |
| Advanced custom needs | custom | Full Vega-Lite spec for custom visualizations |
Dashboards
Dashboards arrange charts and content in a grid layout. See Dashboard Reference for YAML structure, tile types, tabs, and filters.
Exploring the Warehouse
Use lightdash sql to explore data when building models:
lightdash sql "SELECT * FROM orders LIMIT 5" -o preview.csv
lightdash sql "SELECT DISTINCT status FROM orders" -o statuses.csv
lightdash sql "SELECT SUM(amount) FROM orders" -o test.csv
Workflow Patterns
| Pattern | When to Use |
|---|
Direct (deploy + upload) | Solo dev, rapid iteration |
| Preview-First | Team, complex changes |
| CI/CD | Automated on merge |
See Workflows Reference for detailed examples and CI/CD configurations.
Resources
Semantic Layer
Charts
Dashboards & Workflows
External