Create your first project in Lightdash
In Lightdash, everything you need for BI is written as code in your dbt project. You use dbt to transform all of the data from your data warehouse, then you use Lightdash to explore it.
But, before you hook up your dbt project to Lightdash, we need to make sure we have Tables to explore. In this setup guide, we'll walk you through the steps of installing + using the Lightdash CLI and creating the first Tables in your project.
New to dbt? If you haven't used dbt before, follow dbt's getting started guide before proceeding with setting up Lightdash.
What are Tables?โ
Tables are the starting point to any data exploration in Lightdash - they're the data in Lightdash that you can query. The beauty of Lightdash is that we're pretty well synced with your dbt project. So, in Lightdash, Tables actually come from dbt models that have been defined in your dbt project's .yml
files.
If your dbt model has been defined in a .yml file, it will appear in Lightdash as a Table.
Not sure what a .yml file is? Make sure to check out dbt's docs to learn more about building .yml files for your dbt project.
Here's an example of our Community stats daily
model we've defined in dbt. In Lightdash, we can see it in our list of available Tables to explore.
Now that we know what tables are, let's add some and create our first project!
Step 1: Install the Lightdash CLI toolโ
The Lightdash CLI is the recommended way to develop your dbt + Lightdash project. It makes development faster and easier, as well as giving you options for building more powerful automation to manage your Lightdash instance.
Before installing Lightdash CLI, you need to have NodeJS/NPM installed on your machine. To check that, run the following command in your terminal:
node -v; npm -v;
# it should print something like:
# v20.8.0
# 8.15.0
Don't have NodeJS/NPM installed in your system?
We recommend installing NodeJS/NPM using NVM (Node Version Manager) which works for POSIX-compliant shells (sh, dash, ksh, zsh, bash on these platforms: unix, macOS, and windows WSL)
Open your terminal and run the command below to install NVM (Node Version Manager) to your system.
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.2/install.sh | bash
# or
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.2/install.sh | bash
Restart terminal and install NodeJS by running
nvm install --lts
Check that NodeJS is installed by running
node -v
Running the command above should output something like 20.8.0
which means you've succesfully installed NodeJS/NPM ๐
Alternatively, you can install NodeJS/NPM via your preferred package manager.
Run the following on your terminal to install the Lightdash CLI.
npm install -g @lightdash/cli
If you get an npm ERR! code EACCES
error while installing the Lightdash CLI, follow this guide to resolve it.
Step 2: Login to the CLIโ
We've automatically generated a personal access token that you can use to login to the CLI, so you just need to copy-paste that command in your Terminal.
It's Step 2. and should look something like this:
lightdash login https://{{ lightdash_domain }} --token my-super-secret-token
Where {{ lightdash_domain }}
is app.lightdash.cloud
for Lightdash Cloud users. Or your own domain if self-hosting. If you want to login using another method, then you can check out our authentication methods here.
Step 3: Add Tablesโ
If you're using dbt Cloud, you'll need to clone your repo to your local machine before completing the next steps.
To get our dbt project Lightdash-ready, we need to define all of the columns in our dbt models that we want to explore in Lightdash. We've made this really easy to do using our CLI tool and the command:
lightdash dbt run
This will generate Tables and dimensions for your entire dbt project. It will document all of the columns in your models and these are what we explore in Lightdash as Dimensions
.
For example, if we have a projects.yml
file, we'd have a Table called Projects
and it would have the dimensions: Dashboards created num total
and Days since project created
.
Error: Not a dbt project (or any of the parent directories). Missing dbt_project.yml file
If you only want to generate Tables and dimensions for some of the models in your dbt project, check this outโ
Generate Tables and dimensions for some of the models in my dbt project:
{{
config(
materialized='table',
tags=['lightdash']
)
}}
The lightdash dbt run
command supports dbt model selection syntax to generate .yml files for a group of models. This means you can use tags or other model selection syntax to specify which models you want to generate dimensions for in your dbt project.
lightdash dbt run -s tag:lightdash # all models with the lightdash tag
lightdash dbt run -s payments # just payments
lightdash dbt run -s payments+ # payments and all children
lightdash dbt run -s +payments # payments and all parents
lightdash dbt run -s payments+ +customers tag:lightdash # mix and match
Step 4: Create your projectโ
Now, your dbt project is Lightdash-ready! Just run this command and follow the link to start exploring your data:
lightdash deploy --create
Next steps: Update your project connection settingsโ
We create your first project using your local dbt profiles.yml
file. So, you might want to update your connection settings to:
- Set up a service account for Lightdash to run on (instead of using your personal connection details)
- Connect Lightdash to your version controlled dbt project so changes are automatically synced.
Check out details on updating your connection settings here.