askill
prisma-upgrade-v7-env-variables

prisma-upgrade-v7-env-variablesSafety 95Repository

Environment Variables

0 stars
1.2k downloads
Updated 2/9/2026

Package Files

Loading files...
SKILL.md

Environment Variables

Prisma v7 no longer automatically loads environment variables. You must load them explicitly.

The Change

v6 Behavior

Prisma CLI automatically loaded .env files.

v7 Behavior

You must manually load environment variables using dotenv or similar.

Setup

1. Install dotenv

npm install dotenv

2. Import in prisma.config.ts

import 'dotenv/config'  // Must be first import
import { defineConfig, env } from 'prisma/config'

export default defineConfig({
  datasource: {
    url: env('DATABASE_URL'),
  },
})

Bun Users

Bun automatically loads .env files. No additional setup needed:

// prisma.config.ts (Bun)
import { defineConfig, env } from 'prisma/config'

export default defineConfig({
  datasource: {
    url: env('DATABASE_URL'),
  },
})

Multiple .env Files

Using dotenv-cli

npm install -D dotenv-cli
{
  "scripts": {
    "db:migrate": "dotenv -e .env.local -- prisma migrate dev",
    "db:push": "dotenv -e .env.development -- prisma db push"
  }
}

Using dotenv with path

// prisma.config.ts
import { config } from 'dotenv'
import path from 'path'

// Load specific .env file
config({ path: path.join(__dirname, '.env.local') })

import { defineConfig, env } from 'prisma/config'

export default defineConfig({
  datasource: {
    url: env('DATABASE_URL'),
  },
})

Application Code

For your application, load env vars at startup:

Entry point

// index.ts
import '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 })

Or use dotenv explicitly

import { config } from 'dotenv'
config()

// Now process.env.DATABASE_URL is available

Removed Environment Variables

These Prisma-specific env vars are removed in v7:

Removed VariableAlternative
PRISMA_CLI_QUERY_ENGINE_TYPENot needed (no engines)
PRISMA_CLIENT_ENGINE_TYPENot needed (no engines)
PRISMA_QUERY_ENGINE_BINARYNot needed
PRISMA_QUERY_ENGINE_LIBRARYNot needed
PRISMA_GENERATE_SKIP_AUTOINSTALLNot needed
PRISMA_SKIP_POSTINSTALL_GENERATENot needed
PRISMA_GENERATE_IN_POSTINSTALLNot needed
PRISMA_GENERATE_DATAPROXYUse --no-engine flag
PRISMA_GENERATE_NO_ENGINEUse --no-engine flag
PRISMA_CLIENT_NO_RETRYConfigure on adapter
PRISMA_MIGRATE_SKIP_GENERATENot needed (auto-generate removed)
PRISMA_MIGRATE_SKIP_SEEDNot needed (auto-seed removed)

TypeScript env() Helper

The env() function from prisma/config provides type safety:

import { env } from 'prisma/config'

// Type-safe environment variable access
const url = env('DATABASE_URL')  // string

Note: This only works within prisma.config.ts, not in your application code.

CI/CD Considerations

Ensure environment variables are set in your CI environment:

# GitHub Actions
env:
  DATABASE_URL: ${{ secrets.DATABASE_URL }}

steps:
  - run: npx prisma migrate deploy

No need for dotenv in CI if variables are set directly.

Install

Download ZIP
Requires askill CLI v1.0+

AI Quality Score

85/100Analyzed 2/22/2026

High-quality technical reference for Prisma v7 environment variable migration. Provides clear before/after comparison, actionable setup steps for multiple scenarios (dotenv, Bun, multiple .env files), code examples, removed env vars table, and CI/CD guidance. Slightly vague description ("Environment Variables") but content is comprehensive and well-structured. Tags aid discoverability and it's in a dedicated skills folder.

95
90
72
78
92

Metadata

Licenseunknown
Version-
Updated2/9/2026
Publisherprisma

Tags

ci-cdgithubgithub-actions