Skip to main content
Version: Next

Database

In this section, we'll discuss what happens with the database when your app goes live. When you develop your app locally, you probably use a local dev database (started with wasp start db or some other way). However, when it's time to deploy your app, you'll need to set up a production database.

Production database requirements

The server app that Wasp generates uses a PostgreSQL database. The only requirement from Wasp's point of view is that the database is accessible from the server via the DATABASE_URL server env variable.

It can be a PostgreSQL database running on the same server as the server app, or it can be a managed PostgreSQL database service like Fly Postgres, AWS RDS, or some other service.

Migrations

Every time you make a change in your Prisma schema e.g. adding a new model, changing a field type, etc., you need to create a migration. Migrations are some code that describes the change you made in the schema, and they are used to apply the change to the database.

The benefit of migrations is that you can apply the same change to multiple databases. If there are multiple people working on the project, they can all apply the same changes to their local databases. When you deploy the app to production, the same chaanges are applied to the production database.

Creating migrations

After you made a change in the Prisma schema, you can create a migration by running the following command:

wasp db migrate-dev

This command will create a new migration in the migrations directory. The migration is a set of SQL commands that describe the change you made in the schema.

Applying migrations

In development, the migrations are applied as soon as you run the wasp start command.

In production, the server app first checks if there are any new migrations that need to be applied, and if there are, it applies them before starting the server. This way, the database schema is always in sync with the Prisma schema.

How it works

In the built server app, there are two npm scripts: start and start-production. The start script is used in development, and the start-production script is used in production. The start-production script first applies any pending migrations before starting the server.

The migrations might fail to apply if there is a conflict with the existing data in the database. In that case, you'll need to fix the migration and try again.

Debugging failed migrations

If a migration fails to apply, the server app will log the error message and stop. You should then connect to the production database and see what went wrong. If you check the _prisma_migrations table, you'll see the failed migration there.

You can try resolving the erorr e.g. if you tried adding a @unique constraint to a field that already has duplicate values:

  1. Remove any duplicate values from the database
  2. Remove the failed migration from the _prisma_migrations table
  3. Try applying the migration again by restarting the server app
Viewing the _prisma_migrations table

You can't use the wasp db studio command to view the _prisma_migrations table in the production database, but you can use a database management tool like DBeaver or pgAdmin.

Connect to the production database

In development, you can use the wasp db studio command to open a web-based database management tool that allows you to inspect the database.

You can use the same tool to inspect the production database, but you'll need to set the DATABASE_URL env variable to point to the production database. Set the DATABASE_URL env variable in your terminal before running the wasp db studio command:

DATABASE_URL="postgresql://user:password@host:port/dbname" wasp db studio
Be careful with the DATABASE_URL env variable

Setting the DATABASE_URL env variable in the .env.server file to point to your production database also works, but then you might forget to remove it and you could accidentally make changes to the production database when you run wasp start in development.

That's why we recommend setting the DATABASE_URL env variable in the terminal to avoid this.

If you are looking how to connect to a Fly.io production database, we wrote a guide on how to do that.