PostgreSQL Setup
Configure Prisma with PostgreSQL.
Prerequisites
- •PostgreSQL database (local or cloud)
- •Connection string
1. Schema Configuration
In prisma/schema.prisma:
prisma
datasource db {
provider = "postgresql"
}
generator client {
provider = "prisma-client"
output = "../generated"
}
2. Config Configuration (v7)
In prisma.config.ts:
typescript
import { defineConfig, env } from 'prisma/config'
export default defineConfig({
schema: 'prisma/schema.prisma',
datasource: {
url: env('DATABASE_URL'),
},
})
3. Environment Variable
In .env:
env
DATABASE_URL="postgresql://user:password@localhost:5432/mydb?schema=public"
Connection String Format
code
postgresql://USER:PASSWORD@HOST:PORT/DATABASE?schema=SCHEMA
- •USER: Database user
- •PASSWORD: Password (URL encoded if special chars)
- •HOST: Hostname (localhost, IP, or domain)
- •PORT: Port (default 5432)
- •DATABASE: Database name
- •SCHEMA: Schema name (default
public)
Driver Adapter (Prisma ORM 7 required)
Prisma ORM 7 uses the query compiler by default, so you must use a driver adapter.
- •
Install adapter and driver:
bashnpm install @prisma/adapter-pg pg
- •
Instantiate Prisma Client with the adapter:
typescriptimport 'dotenv/config' import { PrismaClient } from '../generated/client' import { PrismaPg } from '@prisma/adapter-pg' const adapter = new PrismaPg({ connectionString: process.env.DATABASE_URL }) const prisma = new PrismaClient({ adapter })
Common Issues
"Can't reach database server"
- •Check host and port
- •Check firewall settings
- •Ensure database is running
"Authentication failed"
- •Check user/password
- •Special characters in password must be URL-encoded
"Schema does not exist"
- •Ensure
?schema=public(or your schema) is in the URL