Database Migrations
How to manage schema migrations for your Supabase project.
Database migrations are SQL statements that create, update, or delete your existing database schemas. They are a common way of tracking changes to your database over time.
Schema migrations
For this guide, we'll create a table called employees
and see how we can make changes to it.
You will need to install the Supabase CLI and start the local development stack.
Create your first migration file
To get started, generate a new migration to store the SQL needed to create our employees
table.
Add the SQL to your migration file
This creates a new migration file in supabase/migrations directory.
To that file, add the SQL to create this employees
table.
Apply your first migration
Run this migration to create the employees
table.
Now you can visit your new employees
table in the local Dashboard.
Modify your employees table
Next, modify your employees
table by adding a column for department
.
Add a new column to your table
To that new migration file, add the SQL to create a new department
column.
Apply your second migration
Run this migration to update your existing employees
table.
Finally, you should see the department
column added to your employees
table in the local Dashboard.
View the complete code for this example on GitHub.
Seeding data
Now that you are managing your database with migrations scripts, it would be great have some seed data to use every time you reset the database.
Populate your table
Create a seed script in supabase/seed.sql.
To that file, add the SQL to insert data into your employees
table.
Reset your database
Reset your database to reapply migrations and populate with seed data.
You should now see the employees
table, along with your seed data in the Dashboard! All of your database changes are captured in code, and you can reset to a known state at any time, complete with seed data.
Diffing changes
This workflow is great if you know SQL and are comfortable creating tables and columns. If not, you can still use the Dashboard to create tables and columns, and then use the CLI to diff your changes and create migrations.
Create your table from the Dashboard
Create a new table called cities
, with columns id
, name
and population
.
Then generate a schema diff.
Add schema diff as a migration
A new migration file is created for you.
Alternately, you can copy the table definitions directly from the Table Editor.
Test your migration
Test your new migration file by resetting your local database.
The last step is deploying these changes to a live Supabase project.
Deploy your project
You've been developing your project locally, making changes to your tables via migrations. It's time to deploy your project to the Supabase Platform and start scaling up to millions of users!
Head over to Supabase and create a new project to deploy to.
Visiting your live project on Supabase, you'll see a new employees
table, complete with the department
column you added in the second migration above.