Drizzle
Connecting with Drizzle
Drizzle ORM is a TypeScript ORM for SQL databases designed with maximum type safety in mind. You can use their ORM to connect to your database.
If you plan on solely using Drizzle instead of the Supabase Data API (PostgREST), you can turn off the latter in the API Settings.
1
Install
Install Drizzle and related dependencies.
12npm i drizzle-orm postgresnpm i -D drizzle-kit2
Create your models
Create a schema.ts file and define your models.
1234567import { pgTable, serial, text, varchar } from "drizzle-orm/pg-core";export const users = pgTable('users', {  id: serial('id').primaryKey(),  fullName: text('full_name'),  phone: varchar('phone', { length: 256 }),});3
Connect
Connect to your database using the Connection Pooler.
From the project  Connect panel, copy the URI from the "Shared Pooler" option and save it as the DATABASE_URL environment variable. Remember to replace the password placeholder with your actual database password.
12345678910import 'dotenv/config'import { drizzle } from 'drizzle-orm/postgres-js'import postgres from 'postgres'const connectionString = process.env.DATABASE_URL// Disable prefetch as it is not supported for "Transaction" pool modeexport const client = postgres(connectionString, { prepare: false })export const db = drizzle(client);