How to connect a NextJs application to Supabase with Prisma?
3 min read
Table of contents
Definitions:
NextJs: A React framework that can be used to create full-stack web applications.
Supabase: Supabase is an open-source backend-as-a-service (BaaS) platform. It is built on top of Postgres and supports the SQL language. We will use supabase to store our data. That is the database.
Prisma: Prisma is an open-source database toolkit and object-relational mapping (ORM) tool for building scalable, type-safe, and performant database queries. We will use it to read and write data to the database.
To successfully do this, we will need to follow the following steps:
1. Create a NextJs application.
2. Start a supabase project.
3. Download Prisma and connect the application and database.
The first step is to create a NextJs app with npx create-next-app. For our tutorial, I am calling the project "tutorial" and using TypeScript.
data:image/s3,"s3://crabby-images/70b84/70b84588728d1c572a0122b250243bd1bd5a74d4" alt=""
Once the installation is done, we have to cd into the folder [cd tutorial] and run "npm run dev" and it should start the development server on https://localhost:3000
The second step is to create a supabase project. For that, we have to do the following steps:
-
Go to supabase.com
-
Click on Start Your Project and then sign in or signup if you don't have an account.
-
A dashboard will appear where you should have a button called "New Project", click on that button.
data:image/s3,"s3://crabby-images/9b3f0/9b3f0f0843573c4fc765aaeeda07f7ae20a4ffc0" alt=""
-
Provide a name for the project, and a password, and then click on "Create new project". In case you used the password generator, copy and paste the password somewhere safe since we will need to use it soon.
data:image/s3,"s3://crabby-images/92f57/92f57d5d5f3ca50408ec9ce861a7a17e47907bcb" alt="Creating a new project named tutorial"
-
We can also get the database URL now which we will use to connect our application with the help of Prisma. To get the URL we need to go to "Settings [It is on the left side bar] -->Database --> Scroll down to Connection Pooling --> Connection String. [Look at the image below if you have any questions]
data:image/s3,"s3://crabby-images/23272/2327270e9499154f0e3ed3fcae91c7d8833dca4e" alt=""
To connect our NextJs application to supabase we will use Prisma. For that, we will follow the following steps:
1. In our terminal, we will start another instance, run "npm install prisma", and then execute "npx prisma init" to create a prisma project inside our NextJs application.
data:image/s3,"s3://crabby-images/6a470/6a47029259dd908e852537e7a3091458448819f9" alt=""
-
Once our project has been initialized inside our application, we will go to prisma --> schema.prisma
data:image/s3,"s3://crabby-images/889cb/889cbf396fcfc1273bc6f62ee9a4be975a2d88aa" alt=""
-
Now we need to go back to our supabase project site to get the DATABASE_URL.
-
Once we have the URL we need to go to the .env file and paste it there with our password.
data:image/s3,"s3://crabby-images/a64e9/a64e995a2829167a0f939af2fa300d0ab6d1a421" alt=""
That's all there is to it; your supabase database is now linked to your NextJs application via Prisma.
I hope this article helped you.
Happy hacking!