skills
This commit is contained in:
@@ -0,0 +1,90 @@
|
||||
# Prisma Postgres Setup
|
||||
|
||||
Configure Prisma with Prisma Postgres (Managed).
|
||||
|
||||
## Overview
|
||||
|
||||
Prisma Postgres is a serverless, managed PostgreSQL database optimized for Prisma.
|
||||
|
||||
## Setup via CLI
|
||||
|
||||
You can provision a Prisma Postgres instance directly via the CLI:
|
||||
|
||||
```bash
|
||||
prisma init --db
|
||||
```
|
||||
|
||||
This will:
|
||||
1. Log you into Prisma Data Platform.
|
||||
2. Create a new project and database instance.
|
||||
3. Update your `.env` with the connection string.
|
||||
|
||||
## Connection String
|
||||
|
||||
The connection string starts with `prisma+postgres://`.
|
||||
|
||||
```env
|
||||
DATABASE_URL="prisma+postgres://api_key@host.prisma-data.net/env_id"
|
||||
```
|
||||
|
||||
## 1. Schema Configuration
|
||||
|
||||
In `prisma/schema.prisma`:
|
||||
|
||||
```prisma
|
||||
datasource db {
|
||||
provider = "postgresql" // Use postgresql provider
|
||||
}
|
||||
|
||||
generator client {
|
||||
provider = "prisma-client"
|
||||
output = "../generated"
|
||||
}
|
||||
```
|
||||
|
||||
## 2. Config Configuration
|
||||
|
||||
In `prisma.config.ts`:
|
||||
|
||||
```typescript
|
||||
import { defineConfig, env } from 'prisma/config'
|
||||
|
||||
export default defineConfig({
|
||||
schema: 'prisma/schema.prisma',
|
||||
datasource: {
|
||||
url: env('DATABASE_URL'),
|
||||
},
|
||||
})
|
||||
```
|
||||
|
||||
## Driver Adapter (Prisma ORM 7 required)
|
||||
|
||||
Prisma ORM 7 uses the query compiler by default, so you must use a driver adapter. For Prisma Postgres, use the Prisma Postgres serverless driver adapter.
|
||||
|
||||
1. Install adapter and driver:
|
||||
```bash
|
||||
npm install @prisma/adapter-ppg @prisma/ppg
|
||||
```
|
||||
|
||||
2. Use a **direct TCP** connection string for the adapter (from the Prisma Console) and instantiate Prisma Client:
|
||||
```typescript
|
||||
import 'dotenv/config'
|
||||
import { PrismaClient } from '../generated/client'
|
||||
import { PrismaPostgresAdapter } from '@prisma/adapter-ppg'
|
||||
|
||||
const prisma = new PrismaClient({
|
||||
adapter: new PrismaPostgresAdapter({
|
||||
connectionString: process.env.PRISMA_DIRECT_TCP_URL,
|
||||
}),
|
||||
})
|
||||
```
|
||||
|
||||
## Features
|
||||
|
||||
- **Serverless**: Scales to zero.
|
||||
- **Caching**: Integrated query caching (Accelerate).
|
||||
- **Real-time**: Database events (Pulse).
|
||||
|
||||
## Using with Prisma Client
|
||||
|
||||
Since Prisma ORM 7 requires a driver adapter, use the Prisma Postgres adapter shown above when instantiating Prisma Client.
|
||||
Reference in New Issue
Block a user