Skip to content

Commit 5a04f7f

Browse files
renovate[bot]Copilottobiasdiez
authored
chore(deps): update prisma to v7 (major) (#2898)
> ℹ️ **Note** > > This PR body was truncated due to platform limits. This PR contains the following updates: | Package | Change | [Age](https://docs.renovatebot.com/merge-confidence/) | [Confidence](https://docs.renovatebot.com/merge-confidence/) | |---|---|---|---| | [@prisma/adapter-pg](https://redirect.github.com/prisma/prisma) ([source](https://redirect.github.com/prisma/prisma/tree/HEAD/packages/adapter-pg)) | [`6.15.0` → `7.4.2`](https://renovatebot.com/diffs/npm/@prisma%2fadapter-pg/6.15.0/7.4.2) | ![age](https://developer.mend.io/api/mc/badges/age/npm/@prisma%2fadapter-pg/7.4.2?slim=true) | ![confidence](https://developer.mend.io/api/mc/badges/confidence/npm/@prisma%2fadapter-pg/6.15.0/7.4.2?slim=true) | | [@prisma/client](https://www.prisma.io) ([source](https://redirect.github.com/prisma/prisma/tree/HEAD/packages/client)) | [`6.15.0` → `7.4.2`](https://renovatebot.com/diffs/npm/@prisma%2fclient/6.15.0/7.4.2) | ![age](https://developer.mend.io/api/mc/badges/age/npm/@prisma%2fclient/7.4.2?slim=true) | ![confidence](https://developer.mend.io/api/mc/badges/confidence/npm/@prisma%2fclient/6.15.0/7.4.2?slim=true) | | [prisma](https://www.prisma.io) ([source](https://redirect.github.com/prisma/prisma/tree/HEAD/packages/cli)) | [`6.15.0` → `7.4.2`](https://renovatebot.com/diffs/npm/prisma/6.15.0/7.4.2) | ![age](https://developer.mend.io/api/mc/badges/age/npm/prisma/7.4.2?slim=true) | ![confidence](https://developer.mend.io/api/mc/badges/confidence/npm/prisma/6.15.0/7.4.2?slim=true) | --- ### Release Notes <details> <summary>prisma/prisma (@&#8203;prisma/adapter-pg)</summary> ### [`v7.4.2`](https://redirect.github.com/prisma/prisma/releases/tag/7.4.2) [Compare Source](https://redirect.github.com/prisma/prisma/compare/7.4.1...7.4.2) Today, we are issuing a 7.4.2 patch release focused on bug fixes and quality improvements. #### 🛠 Fixes **Prisma Client** - Fix a case-insensitive `IN` and `NOT IN` filter regression ([#&#8203;29243](https://redirect.github.com/prisma/prisma/pull/29243)) - Fix a query plan mutation issue that resulted in broken cursor queries ([#&#8203;29262](https://redirect.github.com/prisma/prisma/pull/29262)) - Fix an array parameter wrapping issue in push operations ([prisma/prisma-engines#5784](https://redirect.github.com/prisma/prisma-engines/pull/5784)) - Fix `Uint8Array` serialization in nested JSON fields ([#&#8203;29268](https://redirect.github.com/prisma/prisma/pull/29268)) - Fix an issue with MySQL joins that relied on non-strict equality ([#&#8203;29251](https://redirect.github.com/prisma/prisma/pull/29251)) **Driver Adapters** - **[@&#8203;prisma/adapter-mariadb](https://redirect.github.com/prisma/adapter-mariadb)**: Update text column detection to check for a binary collation ([#&#8203;29238](https://redirect.github.com/prisma/prisma/pull/29238)) - **[@&#8203;prisma/adapter-mariadb](https://redirect.github.com/prisma/adapter-mariadb)**: Correct `relationJoins` compatibility check for MariaDB 8.x versions ([#&#8203;29246](https://redirect.github.com/prisma/prisma/pull/29246)) **Schema Engine** - Fix partial index predicate comparison on PostgreSQL and MSSQL ([prisma/prisma-engines#5780](https://redirect.github.com/prisma/prisma-engines/pull/5780)) #### 🙏 Huge thanks to our community Many of the fixes in this release were contributed by our amazing community members. We're grateful for your continued support and contributions that help make Prisma better for everyone! ### [`v7.4.1`](https://redirect.github.com/prisma/prisma/releases/tag/7.4.1) [Compare Source](https://redirect.github.com/prisma/prisma/compare/7.4.0...7.4.1) Today, we are issuing a 7.4.1 patch release focused on bug fixes and quality improvements. ##### 🛠 Fixes **Prisma Client** - Fix cursor-based pagination regression with parameterised values ([#&#8203;29184](https://redirect.github.com/prisma/prisma/pull/29184)) - Preserve `Prisma.skip` through query extension argument cloning ([#&#8203;29198](https://redirect.github.com/prisma/prisma/pull/29198)) - Enable batching of multiple queries inside interactive transactions ([#&#8203;25571](https://redirect.github.com/prisma/prisma/pull/25571)) - Add missing JSON value deserialization for JSONB parameter fields ([#&#8203;29182](https://redirect.github.com/prisma/prisma/pull/29182)) - Apply result extensions correctly for nested and fluent relations ([#&#8203;29218](https://redirect.github.com/prisma/prisma/pull/29218)) - Allow missing config datasource URL and validate only when needed ([prisma/prisma-engines#5777](https://redirect.github.com/prisma/prisma-engines/pull/5777)) **Driver Adapters** - **[@&#8203;prisma/adapter-ppg](https://redirect.github.com/prisma/adapter-ppg)**: Handle null values in type parsers for nullable columns ([#&#8203;29192](https://redirect.github.com/prisma/prisma/pull/29192)) **Prisma Schema Language** - Support `where` argument on field-level `@unique` for partial indexes ([prisma/prisma-engines#5774](https://redirect.github.com/prisma/prisma-engines/pull/5774)) - Add object expression and object member support to schema reformatter ([prisma/prisma-engines#5776](https://redirect.github.com/prisma/prisma-engines/pull/5776)) ##### 🙏 Huge thanks to our community Many of the fixes in this release were contributed by our amazing community members. We're grateful for your continued support and contributions that help make Prisma better for everyone! ### [`v7.4.0`](https://redirect.github.com/prisma/prisma/releases/tag/7.4.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/7.3.0...7.4.0) Today, we are excited to share the `7.4.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — or [follow us on X](https://pris.ly/x)!** ### Highlights #### ORM ##### Caching in Prisma Client Today’s release is a big one, as we introduce a new caching layer into Prisma ORM. But why the need for a caching layer? In Prisma 7, the query compiler runs as a WebAssembly module directly on the JavaScript main thread. While this simplified the architecture by eliminating the separate engine process, it introduced a trade-off: every query now synchronously blocks the event loop during compilation. For individual queries, compilation takes between 0.1ms and 1ms, which is barely noticeable in isolation. But under high concurrency this overhead adds up and creates event loop contention that affects overall application throughput. For instance, say we have a query that is run over and over, but is a similar shape: ```tsx // These two queries have the same shape: const alice = await prisma.user.findUnique({ where: { email: '[email protected]' } }) const bob = await prisma.user.findUnique({ where: { email: '[email protected]' } }) ``` Prior to v7.4.0, this would be reevaluated ever time the query is run. Now, Prisma Client will extract the user-provided values and replaces them with typed placeholders, producing a normalized query shape: ``` prisma.user.findUnique({ where: { email: %1 } }) // cache key ↑ %1 = '[email protected]' (or '[email protected]') ``` This normalized shape is used as a cache key. On the first call, the query is compiled as usual and the resulting plan is stored in an LRU cache. On every subsequent call with the same query shape, regardless of the actual values, the cached plan is reused instantly without invoking the compiler. We have more details on the impact of this change and some deep dives into Prisma architecture in an upcoming blog post! ##### Partial Indexes (Filtered Indexes) Support We're excited to announce **Partial Indexes** support in Prisma! This powerful community-contributed feature allows you to create indexes that only include rows matching specific conditions, significantly reducing index size and improving query performance. Partial indexes are available behind the `partialIndexes` preview feature for PostgreSQL, SQLite, SQL Server, and CockroachDB, with full migration and introspection support. **Basic usage** Enable the preview feature in your schema: ```groovy generator client { provider = "prisma-client-js" previewFeatures = ["partialIndexes"] } ``` **Raw SQL syntax** For maximum flexibility, use the `raw()` function with database-specific predicates: ```groovy model User { id Int @&#8203;id email String status String @&#8203;@&#8203;unique([email], where: raw("status = 'active'")) @&#8203;@&#8203;index([email], where: raw("deletedAt IS NULL")) } ``` **Type-safe object syntax** For better type safety, use the object literal syntax for simple conditions: ```groovy model Post { id Int @&#8203;id title String published Boolean @&#8203;@&#8203;index([title], where: { published: true }) @&#8203;@&#8203;unique([title], where: { published: { not: false } }) } ``` ##### Bug Fixes Most of these fixes are **community contributions** - thank you to our amazing contributors! - [**prisma/prisma-engines#5767**](https://redirect.github.com/prisma/prisma-engines/pull/5767): Fixed an issue with PostgreSQL migration scripts that prevented usage of `CREATE INDEX CONCURRENTLY` in migrations - [**prisma/prisma-engines#5752**](https://redirect.github.com/prisma/prisma-engines/pull/5752): Fixed BigInt precision loss in JSON aggregation for MySQL and CockroachDB by casting BigInt values to text (from community member [polaz](https://redirect.github.com/polaz)) - [**prisma/prisma-engines#5750**](https://redirect.github.com/prisma/prisma-engines/pull/5750): Fixed connection failures with non-ASCII database names by properly URL-decoding database names in connection strings - [**#&#8203;29155**](https://redirect.github.com/prisma/prisma/pull/29155): Fixed silent transaction commit errors in PlanetScale adapter by ensuring COMMIT failures are properly propagated - [**#&#8203;29141**](https://redirect.github.com/prisma/prisma/pull/29141): Resolved race condition errors (EREQINPROG) in SQL Server adapter by serializing commit/rollback operations using mutex synchronization - [**#&#8203;29158**](https://redirect.github.com/prisma/prisma/pull/29158): Fixed MSSQL connection string parsing to properly handle curly brace escaping for passwords containing special characters #### Open roles at Prisma Interested in joining Prisma? We’re growing and have several exciting opportunities across the company for developers who are passionate about building with Prisma. Explore our open positions on our [Careers page](https://www.prisma.io/careers#current) and find the role that’s right for you. #### Enterprise support Thousands of teams use Prisma and many of them already tap into our Enterprise & Agency Support Program for hands-on help with everything from schema integrations and performance tuning to security and compliance. With this program you also get priority issue triage and bug fixes, expert scalability advice, and custom training so that your Prisma-powered apps stay rock-solid at any scale. Learn more or join: <https://prisma.io/enterprise>. ### [`v7.3.0`](https://redirect.github.com/prisma/prisma/releases/tag/7.3.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/7.2.0...7.3.0) Today, we are excited to share the `7.3.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — or [follow us on X](https://pris.ly/x)!** #### ORM - [#&#8203;28976](https://redirect.github.com/prisma/prisma/pull/28976): Fast and Small Query Compilers We've been working on various performance-related bugs since the initial ORM 7.0 release. With 7.3.0, we're introducing a new `compilerBuild` option for the client generator block in `schema.prisma` with two options: `fast` and `small`. This allows you to swap the underlying Query Compiler engine based on your selection, one built for speed (with an increase in size), and one built for size (with the trade off for speed). By default, the `fast` mode is used, but this can be set by the user: ```groovy generator client { provider = "prisma-client" output = "../src/generated/prisma" compilerBuild = "fast" // "fast" | "small" } ``` We still have more in progress for performance, but this new `compilerBuild` option is our first step toward addressing your concerns! - [#&#8203;29005](https://redirect.github.com/prisma/prisma/pull/29005): Bypass the Query Compiler for Raw Queries Raw queries (`$executeRaw`, `$queryRaw`) can now skip going through the query compiler and query interpreter infrastructure. They can be sent directly to the driver adapter, removing additional overhead. - [#&#8203;28965](https://redirect.github.com/prisma/prisma/pull/28965): Update MSSQL to v12.2.0 This community PR updates the `@prisma/adapter-mssql` to use MSSQL v12.2.0. Thanks [Jay-Lokhande](https://redirect.github.com/Jay-Lokhande)! - [#&#8203;29001](https://redirect.github.com/prisma/prisma/pull/29001): Pin better-sqlite3 version to avoid SQLite bug An underlying bug in SQLite 3.51.0 has affected the `better-sqlite3` adapter. We’ve bumped the version that powers `@prisma/better-sqlite3` and have pinned the version to prevent any unexpected issues. If you are using `@prisma/better-sqlite3` , please upgrade to v7.3.0. - [#&#8203;29002](https://redirect.github.com/prisma/prisma/pull/29002): Revert `@map` enums to v6.19.0 behavior In the initial release of v7.0, we made a change with Mapped Enums where the generated enum would get its value from the value passed to the `@map` function. This was a breaking change from v6 that caused issues for many users. We have reverted this change for the time being, as many different diverging approaches have emerged from the community discussion. - [prisma-engines#5745](https://redirect.github.com/prisma/prisma-engines/pull/5745): Cast BigInt to text in JSON aggregation When using `relationJoins` with BigInt fields in Prisma 7, JavaScript's `JSON.parse` loses precision for integers larger than `Number.MAX_SAFE_INTEGER` (2^53 - 1). This happens because PostgreSQL's `JSONB_BUILD_OBJECT` returns BigInt values as JSON numbers, which JavaScript cannot represent precisely. ``` // Original BigInt ID: 312590077454712834 // After JSON.parse: 312590077454712830 (corrupted!) ``` This PR cast BigInt columns to `::text` inside `JSONB_BUILD_OBJECT` calls, similar to how `MONEY` is already cast to `::numeric`. ``` -- Before JSONB_BUILD_OBJECT('id', "id") -- After JSONB_BUILD_OBJECT('id', "id"::text) ``` This ensures BigInt values are returned as JSON strings, preserving full precision when parsed in JavaScript. #### Open roles at Prisma Interested in joining Prisma? We’re growing and have several exciting opportunities across the company for developers who are passionate about building with Prisma. Explore our open positions on our \[[Careers page](https://www.prisma.io/careers#current)]\(<https://www.prisma.io/careers#current>) and find the role that’s right for you. #### Enterprise support Thousands of teams use Prisma and many of them already tap into our Enterprise & Agency Support Program for hands-on help with everything from schema integrations and performance tuning to security and compliance. With this program you also get priority issue triage and bug fixes, expert scalability advice, and custom training so that your Prisma-powered apps stay rock-solid at any scale. Learn more or join: <https://prisma.io/enterprise>. ### [`v7.2.0`](https://redirect.github.com/prisma/prisma/releases/tag/7.2.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/7.1.0...7.2.0) Today, we are excited to share the `7.2.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — or [follow us on X](https://pris.ly/x)!** #### Highlights #### ORM - [#&#8203;28830](https://redirect.github.com/prisma/prisma/pull/28830): feat: add `sqlcommenter-query-insights` plugin - Adds a new SQL commenter plugin to support query insights metadata. - [#&#8203;28860](https://redirect.github.com/prisma/prisma/pull/28860): feat(migrate): add `-url` param for `db pull`, `db push`, `migrate dev` - Adds a `-url` flag to key migrate commands to make connection configuration more flexible. - [#&#8203;28895](https://redirect.github.com/prisma/prisma/pull/28895): feat(config): allow undefined URLs in e.g. `prisma generate` - Allows certain workflows (such as `prisma generate`) to proceed even when URLs are undefined. - [#&#8203;28903](https://redirect.github.com/prisma/prisma/pull/28903): feat(cli): customize `prisma init` based on the JS runtime (Bun vs others) - Makes `prisma init` tailor generated setup depending on whether the runtime is Bun or another JavaScript runtime. - [#&#8203;28846](https://redirect.github.com/prisma/prisma/pull/28846): fix(client-engine-runtime): make `DataMapperError` a `UserFacingError` - Ensures `DataMapperError` is surfaced as a user-facing error for clearer, more actionable error reporting. - [#&#8203;28849](https://redirect.github.com/prisma/prisma/pull/28849): fix(adapter-{pg,neon,ppg}): handle 22P02 error in Postgres - Improves Postgres adapter error handling for invalid-text-representation errors (`22P02`). - [#&#8203;28913](https://redirect.github.com/prisma/prisma/pull/28913): fix: fix byte upserts by removing legacy byte array representation - Fixes byte upsert behavior by removing a legacy byte-array representation path. - [#&#8203;28535](https://redirect.github.com/prisma/prisma/pull/28535): fix(client,internals,migrate,generator-helper): handle multibyte UTF-8 characters split across chunk boundaries in byline - Prevents issues when multibyte UTF-8 characters are split across chunk boundaries during line processing. - [#&#8203;28911](https://redirect.github.com/prisma/prisma/pull/28911): fix(cli): make `prisma version --json` emit JSON only to stdout - Ensures machine-readable JSON output is emitted cleanly to stdout without extra noise. #### VS Code Extension - [#&#8203;1950](https://redirect.github.com/prisma/language-tools/pull/1950): fix: TML-1670 studio connections - Resolves issues related to Studio connections, improving reliability for VS Code or language-server integrations. #### Open roles at Prisma Interested in joining Prisma? We’re growing and have several exciting opportunities across the company for developers who are passionate about building with Prisma. Explore our open positions on our \[[Careers page](https://www.prisma.io/careers#current)]\(<https://www.prisma.io/careers#current>) and find the role that’s right for you. #### Enterprise support Thousands of teams use Prisma and many of them already tap into our Enterprise & Agency Support Program for hands-on help with everything from schema integrations and performance tuning to security and compliance. With this program you also get priority issue triage and bug fixes, expert scalability advice, and custom training so that your Prisma-powered apps stay rock-solid at any scale. Learn more or join: <https://prisma.io/enterprise>. ### [`v7.1.0`](https://redirect.github.com/prisma/prisma/releases/tag/7.1.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/7.0.1...7.1.0) Today, we are excited to share the `7.1.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — or [follow us on X](https://pris.ly/x)!** This release brings quality of life improvements and fixes various bugs. ##### Prisma ORM - [#&#8203;28735](https://redirect.github.com/prisma/prisma/pull/28735): **pnpm monorepo issues with prisma client runtime utils** Resolves issues in pnpm monorepos where users would report TypeScript issues related to `@prisma/client-runtime-utils`. - [#&#8203;28769](https://redirect.github.com/prisma/prisma/pull/28769):  **implement sql commenter plugins for Prisma Client** This PR implements support for SQL commenter plugins to Prisma Client. The feature will allow users to add metadata to SQL queries as comments following the [sqlcommenter format](https://google.github.io/sqlcommenter/). Here’s two related PRs that were also merged: - [#&#8203;28796](https://redirect.github.com/prisma/prisma/pull/28796): **implement query tags for SQL commenter plugin** - [#&#8203;28802](https://redirect.github.com/prisma/prisma/pull/28802): **add `traceContext` SQL commenter plugin** - [#&#8203;28737](https://redirect.github.com/prisma/prisma/pull/28737): **added error message when constructing client without configs** This commit adds an additional error message when trying to create a new PrismaClient instance without any arguments. Thanks to [@&#8203;xio84](https://redirect.github.com/xio84) for this community contribution! - [#&#8203;28820](https://redirect.github.com/prisma/prisma/pull/28820): **mark `@opentelemetry/api` as external in instrumentation** Ensures `@opentelemetry/api` is treated as an external dependency rather than bundled. Since it is a peer dependency, this prevents applications from ending up with duplicate copies of the package. - [#&#8203;28694](https://redirect.github.com/prisma/prisma/pull/28694): **allow `env()` helper to accept interface-based generics** Updates the `env()` helper’s type definition so it works with interfaces as well as type aliases. This removes the previous constraint requiring an index signature and resolves TS2344 errors when using interface-based env types. Runtime behavior is unchanged. Thanks to [@&#8203;SaubhagyaAnubhav](https://redirect.github.com/SaubhagyaAnubhav) for this community contribution! ##### Read Replicas extension - [#&#8203;53](https://redirect.github.com/prisma/extension-read-replicas/pull/53): **Add support for Prisma 7** Users of the read-replicas extension can now use the extension in Prisma v7. You can update by installing: ```bash npm install @&#8203;prisma/extension-read-replicas@latest ``` For folks still on Prisma v6, install version `0.4.1`: ```bash npm install @&#8203;prisma/[email protected] ``` For more information, [visit the repo](https://redirect.github.com/prisma/extension-read-replicas) ##### SQL comments We're excited to announce **SQL Comments** support in Prisma 7.1.0! This new feature allows you to append metadata to your SQL queries as comments, making it easier to correlate queries with application context for improved observability, debugging, and tracing. SQL comments follow the [sqlcommenter format](https://google.github.io/sqlcommenter/) developed by Google, which is widely supported by database monitoring tools. With this feature, your SQL queries can include rich metadata: ```sql SELECT "id", "name" FROM "User" /*application='my-app',traceparent='00-abc123...-01'*/ ``` ##### Basic usage Pass an array of SQL commenter plugins to the new `comments` option when creating a `PrismaClient` instance: ```tsx import { PrismaClient } from './generated/prisma/client'; import { PrismaPg } from '@&#8203;prisma/adapter-pg'; import { queryTags } from '@&#8203;prisma/sqlcommenter-query-tags'; import { traceContext } from '@&#8203;prisma/sqlcommenter-trace-context'; const adapter = new PrismaPg({ connectionString: `${process.env.DATABASE_URL}`, }); const prisma = new PrismaClient({ adapter, comments: [queryTags(), traceContext()], }); ``` ##### Query tags The `@prisma/sqlcommenter-query-tags` package lets you add arbitrary tags to queries within an async context: ```tsx import { queryTags, withQueryTags } from '@&#8203;prisma/sqlcommenter-query-tags'; const prisma = new PrismaClient({ adapter, comments: [queryTags()], }); // Wrap your queries to add tags const users = await withQueryTags( { route: '/api/users', requestId: 'abc-123' }, () => prisma.user.findMany(), ); ``` Resulting SQL: ```sql SELECT ... FROM "User" /*requestId='abc-123',route='/api/users'*/ ``` Use `withMergedQueryTags` to merge tags with outer scopes: ```tsx import { withQueryTags, withMergedQueryTags, } from '@&#8203;prisma/sqlcommenter-query-tags'; await withQueryTags({ requestId: 'req-123', source: 'api' }, async () => { await withMergedQueryTags( { userId: 'user-456', source: 'handler' }, async () => { // Queries here have: requestId='req-123', userId='user-456', source='handler' await prisma.user.findMany(); }, ); }); ``` ##### Trace context The `@prisma/sqlcommenter-trace-context` package adds W3C Trace Context (`traceparent`) headers for distributed tracing correlation: ```tsx import { traceContext } from '@&#8203;prisma/sqlcommenter-trace-context'; const prisma = new PrismaClient({ adapter, comments: [traceContext()], }); ``` When tracing is enabled and the span is sampled: ```sql SELECT * FROM "User" /*traceparent='00-0af7651916cd43dd8448eb211c80319c-b9c7c989f97918e1-01'*/ ``` > Note: Requires [@&#8203;prisma/instrumentation](https://redirect.github.com/prisma/instrumentation) to be configured. The traceparent is only added when tracing is active and the span is sampled. ##### Custom plugins Create your own plugins to add custom metadata: ```tsx import type { SqlCommenterPlugin } from '@&#8203;prisma/sqlcommenter'; const applicationTags: SqlCommenterPlugin = (context) => ({ application: 'my-service', environment: process.env.NODE_ENV ?? 'development', operation: context.query.action, model: context.query.modelName, }); const prisma = new PrismaClient({ adapter, comments: [applicationTags], }); ``` ##### Framework integration SQL comments work seamlessly with popular frameworks, e.g., **Hono**: ```tsx import { createMiddleware } from 'hono/factory'; import { withQueryTags } from '@&#8203;prisma/sqlcommenter-query-tags'; app.use( createMiddleware(async (c, next) => { await withQueryTags( { route: c.req.path, method: c.req.method, requestId: c.req.header('x-request-id') ?? crypto.randomUUID(), }, () => next(), ); }), ); ``` Additional framework examples for **Express**, **Koa**, **Fastify**, and **NestJS** are available in the documentation. For complete documentation, see [SQL Comments](https://www.prisma.io/docs/orm/prisma-client/observability-and-logging/sql-comments). We'd love to hear your feedback on this feature! Please open an issue on [GitHub](https://redirect.github.com/prisma/prisma) or join the discussion in our [Discord community](https://pris.ly/discord). ##### Open roles at Prisma Interested in joining Prisma? We’re growing and have several exciting opportunities across the company for developers who are passionate about building with Prisma. Explore our open positions on our [Careers page](https://www.prisma.io/careers#current) and find the role that’s right for you. ##### Enterprise support Thousands of teams use Prisma and many of them already tap into our Enterprise & Agency Support Program for hands-on help with everything from schema integrations and performance tuning to security and compliance. With this program you also get priority issue triage and bug fixes, expert scalability advice, and custom training so that your Prisma-powered apps stay rock-solid at any scale. Learn more or join: <https://prisma.io/enterprise>. ### [`v7.0.1`](https://redirect.github.com/prisma/prisma/releases/tag/7.0.1) [Compare Source](https://redirect.github.com/prisma/prisma/compare/7.0.0...7.0.1) Today, we are issuing a 7.0.1 patch release focused on quality of life improvements, and bug fixes. #### 🛠 Fixes - **Prisma Studio**: - Support Deno >= 1.4 <2.2 and Bun >= 1 (via [#&#8203;28583](https://redirect.github.com/prisma/prisma/pull/28583)) - Fix collisions between user and internal Studio columns when querying (via [#&#8203;28677](https://redirect.github.com/prisma/prisma/pull/28677)) - Warn when SQLite file doesn't exist (via <https://redirect.github.com/prisma/prisma/pull/28711/commits/c33a1ea9e5a94e6a5c876bc4567915cc5f354658>) - Fix [prisma/studio#1363](https://redirect.github.com/prisma/studio/issues/1363) (via <https://redirect.github.com/prisma/prisma/pull/28711/commits/07224d4651d043f4b08735eeaa144aa9d75f9fe3>) - Sort tables alphabetically (via [#&#8203;28702](https://redirect.github.com/prisma/prisma/pull/28702)) - **Prisma CLI** - Fix potential vulnerabilities in installed dependencies (via [#&#8203;28592](https://redirect.github.com/prisma/prisma/pull/28592)) - Fix [#&#8203;28240](https://redirect.github.com/prisma/prisma/issues/28240), an exit code regression affecting `prisma migrate diff` (via [prisma/prisma-engines#5699](https://redirect.github.com/prisma/prisma-engines/pull/5699)) - Show informative message when `prisma db seed` is run, but no `migrations.seed` command is specified in the Prisma config file (via [#&#8203;28711](https://redirect.github.com/prisma/prisma/pull/28711)) - Relax `engines` check in `package.json`, to let Node.js 25+ users adopt Prisma, although Node.js 25+ isn't considered stable yet (via [#&#8203;28600](https://redirect.github.com/prisma/prisma/pull/28600)). Thanks [@&#8203;Sajito](https://redirect.github.com/Sajito)! - **Prisma Client** - Restore `cockroachdb` support in `prisma-client-js` generator, after it was accidentally not shipped in Prisma 7.0.0 (via [#&#8203;28690](https://redirect.github.com/prisma/prisma/pull/28690)) - **[@&#8203;prisma/better-sqlite3](https://redirect.github.com/prisma/better-sqlite3)** - Bump underlying version of `better-sqlite3` to `^12.4.5`, fixing [#&#8203;28624](https://redirect.github.com/prisma/prisma/issues/28624) (via [#&#8203;28625](https://redirect.github.com/prisma/prisma/pull/28625)). Thank you [@&#8203;bhbs](https://redirect.github.com/bhbs)! ### [`v7.0.0`](https://redirect.github.com/prisma/prisma/releases/tag/7.0.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/6.19.2...7.0.0) Today, we are excited to share the `7.0.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — and [follow us on X](https://pris.ly/x)!** ### Highlights Over the past year we focused on making it simpler and faster to build applications with Prisma, no matter what tools you use or where you deploy, with exceptional developer experience at it’s core. This release makes many features introduced over the past year as the new defaults moving forward. #### Prisma ORM ##### ESM Prisma Client as the default The Rust-free/ESM Prisma Client has been in the works for some time now, all the way [back to v6.16.0](https://www.prisma.io/docs/orm/more/upgrade-guides/upgrading-versions/upgrading-to-prisma-6), with early iterations being available for developers to adopt. Now with version 7.0, we’re making this the default for all new projects. With this, developers are able to get: - \~90% smaller bundle sizes - Up to 3x faster queries - Significantly simpler deployments Adopting the new client is as simple as swapping the `prisma-client-js` provider for `prisma-client` in your main `schema.prisma` : ```diff // schema.prisma generator client { - provider = "prisma-client-js" + provider = "prisma-client" } ``` ##### Prisma Client changes In v7, we've moved to requiring users pass either an adapter or `accelerteUrl` when creating a new instance of `PrismaClient`. For Driver Adapters ```tsx import { PrismaClient } from './generated/prisma/client'; import { PrismaPg } from '@&#8203;prisma/adapter-pg'; const adapter = new PrismaPg({ connectionString: process.env.DATABASE_URL }); const prisma = new PrismaClient({ adapter }); ``` For other databases: ```tsx // If using SQLite import { PrismaBetterSqlite3 } from '@&#8203;prisma/adapter-better-sqlite3'; const adapter = new PrismaBetterSqlite3({ url: process.env.DATABASE_URL || 'file:./dev.db' }) // If using MySql import { PrismaMariaDb } from '@&#8203;prisma/adapter-mariadb'; const adapter = new PrismaMariaDb({ host: "localhost", port: 3306, connectionLimit: 5 }); ``` We’ve also removed support for additional options when configuring your Prisma Client - `new PrismaClient({ datasources: .. })` support has been removed - `new PrismaClient({datasourceUrl: ..})` support has been removed - `new PrismaClient()` support has been removed - `new PrismaClient({})` support has been removed For Prisma Accelerate users: ```tsx import { PrismaClient } from "./generated/prisma/client" import { withAccelerate } from "@&#8203;prisma/extension-accelerate" const prisma = new PrismaClient({ accelerateUrl: process.env.DATABASE_URL, }).$extends(withAccelerate()) ``` ##### Generated Client and types move out of `node_modules` When running `prisma generate`, the generated Client runtime and project types will now **require** a `output` path to be set in your project’s main `schema.prisma`. We recommend that they be generated inside of your project’s `src` directory to ensure that your existing tools are able to consume them like any other piece of code you might have. ```groovy // schema.prisma generator client { provider = "prisma-client" // Generate my Client and Project types output = "../src/generated/prisma" } ``` Update your code to import `PrismaClient` from this generated output: ```tsx // Import from the generated prisma client import { PrismaClient } from './generated/prisma/client'; ``` For developers who still need to stay on the `prisma-client-js` but are using the new `output` option, theres’s a new required package, `@prisma/client-runtime-utils` , which needs to be installed: ```bash # for prisma-client-js users only npm install @&#8203;prisma/client-runtime-utils ``` ##### Removal of implicit Prisma commands In previous releases, Prisma would run `generate` and `seed` in various situations: - post-install hook would run `prisma generate` - `prisma migrate` would run `prisma generate` and `prisma seed` This behaviour has been removed in favor of explicitly requiring commands to be run by users. ##### Removal of `prisma generate` flags For `prisma generate` , we’ve removed a few flags that were no longer needed: - `prisma generate --data-proxy` - `prisma generate --accelerate` - `prisma generate --no-engine` - `prisma generate --allow-no-models` ##### Removal of `prisma db` flags For `prisma db`, we’ve removed the following flag: - `prisma db pull --local-d1` This parameter no longer exists but equivalent functionality can be implemented by defining a config file with a connection string for the local D1 database. We provide a helper function listLocalDatabases in the D1 adapter to simplify the migration: ```ts import { defineConfig } from '@&#8203;prisma/config' import { listLocalDatabases } from '@&#8203;prisma/adapter-d1' export default defineConfig({ datasource: { url: `file://${listLocalDatabases().pop()}`, }, }) ``` ##### Removal of `prisma migrate` flags For `prisma migrate diff`, we’ve removed the following flags: - `prisma --[from/to]-schema-datamodel` - This is now replaced with just `--[from/to]-schema`. The usage is otherwise the same. - `prisma --[from/to]-url`, `prisma --[from/to]-schema-datasource` - These are now replaced with `--[from/to]-config-datasource`. The user is expected to populate the datasource in the config file and use the new flag. We no longer support diffing two different URLs/datasources, since only one config can be used at a time. - `prisma --[from/to]-local-d1` - These are now replaced with `--[from/to]-config-datasource`. The user is expected to populate the datasource in the config file and use the new flag with a minor complication due to the fact that it needs to reference the local D1 database. Our `listLocalDatabases` helper function can be used for that, analogously to the `db pull --local-d1` example above (where the user sets the datasource URL to `file://${listLocalDatabases().pop()}`) ##### MongoDB support in Prisma 7 Currently, MongoDB is not supported in Prisma 7. For folks using MongoDB, please stay on Prisma v6. We aim to add support for MongoDB in a future release. ##### Driver Adapter naming updates We’ve standardized our naming conventions for the various driver adapters internally. The following driver adapters have been updated: - `PrismaBetterSQLite3` ⇒ `PrismaBetterSqlite3` - `PrismaD1HTTP` ⇒ `PrismaD1Http` - `PrismaLibSQL` ⇒ `PrismaLibSql` - `PrismaNeonHTTP` ⇒ `PrismaNeonHttp` ##### Schema and config file updates As part of a larger change in how the Prisma CLI reads your project configuration, we’ve updated what get’s set the schema, and what gets set in the `prisma.config.ts` . Also as part of this release, `prisma.config.ts` is now required for projects looking to perform introspection and migration. **Schema changes** - `datasource.url` is now configured in the config file - `datasource.shadowDatabaseUrl` is now configured in the config file - `datasource.directUrl` has been made unnecessary and has removed - `generator.runtime=”react-native”` has been removed For early adopters of the config file, a few things have been removed with this release - `engine: 'js'| 'classic'` has been removed - `adapter` has been removed A brief before/after: ```groovy // schema.prisma datasource db { provider = "postgresql" url = ".." directUrl = ".." shadowDatabaseUrl = ".." } ``` ```tsx // ./prisma.config.ts export default defineConfig({ datasource: { url: '..', shadowDatabaseUrl: '..', } }) ``` ##### Explicit loading of environment variables As part of the move to Prisma config, we’re no longer automatically loading environment variables when invoking the Prisma CLI. Instead, developers can utilize libraries like `dotenv` to manage their environment variables and load them as they need. This means you can have dedicated local environment variables or ones set only for production. This removes any accidental loading of environment variables while giving developers full control. ##### Removed support for `prisma` keyword in `package.json` In previous releases, users could configure their schema entry point and seed script in a `prisma` block in the `package.json` of their project. With the move to `prisma.config.ts`, this no longer makes sense and has been removed. To migrate, use the Prisma config file instead: ```json { "name": "my-project", "version": "1.0.0", "prisma": { "schema": "./custom-path-to-schema/schema.prisma", "seed": "tsx ./prisma/seed.ts" } } ``` ```tsx import 'dotenv/config' import { defineConfig, env } from "prisma/config"; export default defineConfig({ schema: "prisma/schema.prisma", migrations: { seed: "tsx prisma/seed.ts" }, datasource: {...}, }); ``` ##### Removed Client Engines: We’ve removed the following client engines: - `LibraryEngine` (`engineType = "library"`, the Node-API Client) - `BinaryEngine` (`engineType = "binary"`, the long-running executable binary) - `DataProxyEngine` and `AccelerateEngine` (Accelerate uses a new `RemoteExecutor` now) - `ReactNativeEngine` ##### Deprecated metrics feature has been removed We deprecated the previewFeature `metrics` some time ago, and have removed it fully for version 7. If you need metrics related data available, you can use the underlying driver adapter itself, like the Pool metric from the Postgres driver. ##### Miscellaneous - [#&#8203;28493](https://redirect.github.com/prisma/prisma/pull/28493): Stop shimming `WeakRef` in Cloudflare Workers. This will now avoid any unexpected memory leaks. - [#&#8203;28297](https://redirect.github.com/prisma/prisma/pull/28297): Remove hardcoded URL validation. Users are now required to make sure they don’t include sensitive information in their config files. - [#&#8203;28273](https://redirect.github.com/prisma/prisma/pull/28273): Removed Prisma v1 detection - [#&#8203;28343](https://redirect.github.com/prisma/prisma/pull/28343): Remove undocumented `--url` flag from `prisma db pull` - [#&#8203;28286](https://redirect.github.com/prisma/prisma/pull/28286): Remove deprecated `prisma introspect` command. - [#&#8203;28480](https://redirect.github.com/prisma/prisma/pull/28480): Rename `/wasm` to `/edge` - This change only affects `prisma-client-js` - Before: - `/edge` → meant “for Prisma Accelerate” - `/wasm` → meant “for Edge JS runtimes (e.g., Cloudflare, Vercel Edge)” - After: - `/edge` → means “for Edge JS runtimes (e.g., Cloudflare, Vercel Edge)” - The following Prisma-specific environment variables have been removed - `PRISMA_CLI_QUERY_ENGINE_TYPE` - `PRISMA_CLIENT_ENGINE_TYPE` - `PRISMA_QUERY_ENGINE_BINARY` - `PRISMA_QUERY_ENGINE_LIBRARY` - `PRISMA_GENERATE_SKIP_AUTOINSTALL` - `PRISMA_SKIP_POSTINSTALL_GENERATE` - `PRISMA_GENERATE_IN_POSTINSTALL` - `PRISMA_GENERATE_DATAPROXY` - `PRISMA_GENERATE_NO_ENGINE` - `PRISMA_CLIENT_NO_RETRY` - `PRISMA_MIGRATE_SKIP_GENERATE` - `PRISMA_MIGRATE_SKIP_SEED` ##### Mapped enums If [you followed along on twitter](https://x.com/prisma/status/1988970132690071600), you will have seen that we teased a highly-request user feature was coming to v7.0. That highly-requested feature is…. mapped emuns! We now support the `@map` attribute for enum members, which can be used to set their expected runtime values ```groovy enum PaymentProvider { MixplatSMS @&#8203;map("mixplat/sms") InternalToken @&#8203;map("internal/token") Offline @&#8203;map("offline") @&#8203;@&#8203;map("payment_provider") } ``` ```tsx export const PaymentProvider: { MixplatSMS: 'mixplat/sms' InternalToken: 'internal/token' Offline: 'offline' } ``` #### New Prisma Studio comes to the CLI We launched a new version of Prisma Studio to our Console and VS Code extension a while back, but the Prisma CLI still shipped with the older version. Now, with v7.0, we’ve updated the Prisma CLI to include the new Prisma Studio. Not only are you able to inspect your database, but you get rich visualization to help you understand connected relationships in your database. It’s customizable, much smaller, and can inspect remote database by passing a `--url` flag. This new version of Prisma Studio is not tied to the Prisma ORM, and establishes a new foundation for what comes next. Currently, the new studio only supports Postgres, MySQL, and SQLite, with support for other databases coming in a future release. For issues related to Prisma Studio, please direct them to the [Studio repo on github](https://redirect.github.com/prisma/studio). ![ScreenRecording2025-11-18at7 40 46PM-ezgif com-video-to-gif-converter](https://redirect.github.com/user-attachments/assets/0509b554-cbc6-48cc-adc5-ba491759895c) #### Prisma Postgres [Prisma Postgres](https://www.prisma.io/postgres) is our managed Postgres service, designed with the same philosophy of great DX that has guided Prisma for close to a decade. It works great with serverless, it’s fast, and with simple pricing and a generous free tier. Here’s what’s new: ##### Connection Pooling Changes with Prisma Accelerate With support for connection pooling being added natively to Prisma Postgres, Prisma Accelerate now serves as a dedicated caching layer. If you were using Accelerate for the connection pooling features, don’t worry! Your existing connection string via Accelerate will continue to work, and you can switch to the new connection pool when you’re ready. ##### Simplified connection flow We've made connecting to Prisma Postgres even simpler. Now, when you go to connect to a database, you’ll get new options to enable connection pooling, or to enable Prisma Accelerate for caching. Below, you’ll get code snippets for getting things configured in your project right away. ![Clipboard-20251119-110343-691](https://redirect.github.com/user-attachments/assets/172b43ee-70b3-43c7-a3ca-2cc12873d1a4) ##### Serverless driver For those who want to connect to Prisma Postgres but are deploying to environments like Cloudflare Workers, we have a new version of the serverless client library to support these runtimes. - Compatible with Cloudflare Workers, Vercel Edge Functions, Deno Deploy, AWS Lambda, and Bun - Stream results row-by-row to handle large datasets with constant memory usage - Pipeline multiple queries over a single connection, reducing latency by up to 3x - SQL template literals with automatic parameterization and full TypeScript support - Built-in transactions, batch operations, and extensible type system [Check out the serverless driver docs](https://www.prisma.io/docs/postgres/database/serverless-driver) for more details #### Open roles at Prisma Interested in joining Prisma? We’re growing and have several exciting opportunities across the company for developers who are passionate about building with Prisma. Explore our open positions on our [Careers page](https://www.prisma.io/careers#current) and find the role that’s right for you. #### Enterprise support Thousands of teams use Prisma and many of them already tap into our Enterprise & Agency Support Program for hands-on help with everything from schema integrations and performance tuning to security and compliance. With this program you also get priority issue triage and bug fixes, expert scalability advice, and custom training so that your Prisma-powered apps stay rock-solid at any scale. Learn more or join: <https://prisma.io/enterprise>. ### [`v6.19.2`](https://redirect.github.com/prisma/prisma/releases/tag/6.19.2) [Compare Source](https://redirect.github.com/prisma/prisma/compare/6.19.1...6.19.2) Today, we are issuing a 6.19.2 patch release in the Prisma 6 release line. It fixes an issue with Prisma Accelerate support in some edge runtime configurations when the `@prisma/client/edge` entrypoint is not being used. Changes: - [#&#8203;28934](https://redirect.github.com/prisma/prisma/pull/28934) ### [`v6.19.1`](https://redirect.github.com/prisma/prisma/releases/tag/6.19.1) [Compare Source](https://redirect.github.com/prisma/prisma/compare/6.19.0...6.19.1) Today, we are issuing a patch release for Prisma 6 that includes a fix for a [diffing bug introduced in Prisma 6.13.1](https://redirect.github.com/prisma/prisma/issues/28240), which led to incorrectly reported empty diffs. #### Changes - [prisma/prisma-engines#5706](https://redirect.github.com/prisma/prisma-engines/pull/5706) ### [`v6.19.0`](https://redirect.github.com/prisma/prisma/releases/tag/6.19.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/6.18.0...6.19.0) Today, we are excited to share the `6.19.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — or [follow us on X](https://pris.ly/x)** ### Highlights This release brings a lot of bug fixes and improvements to both the ORM and Prisma Postgres. #### [Prisma ORM](https://www.prisma.io/orm) Prisma ORM is the most popular ORM in the TypeScript ecosystem. Today’s release brings a bunch of new bug fixes and overall improvements: - [#&#8203;5675](https://redirect.github.com/prisma/prisma-engines/pull/5675): When dropping a model from a schema, do not append the default schema to the migration. - [#&#8203;5656](https://redirect.github.com/prisma/prisma-engines/pull/5656): Align naming conventions for fields and relation fields - [#&#8203;28341](https://redirect.github.com/prisma/prisma/pull/28341): Add biome ignore comments to generated client files. This was a community contribution from [@&#8203;lonelyevil](https://redirect.github.com/lonelyevil), thank you! #### [Prisma Postgres](https://www.prisma.io/postgres) [Prisma Postgres](https://www.prisma.io/postgres) is our fully managed Postgres service, designed with the same philosophy of great DX that has guided Prisma for close to a decade. With this release, we are introducing the following improvements: ##### Connection pooling with Prisma Postgres We added support for direct connections in 6.17, opening Prisma Postgres up to working with any tool in the wider Postgres ecosystem. Now, you can confirm that connection to support connection pooling by appending the query parameter `pool=true` to the connection string. ``` postgres://555555..../postgres?sslmode=require&pool=true ``` #### VS Code extension A frequently requested feature is to be able to use a [local Prisma Postgres database](https://www.prisma.io/docs/postgres/database/local-development) within our VS Code Extension without having to log in. In this release, we’re happy to share that this is now supported! Now you can work on your project without having to connect to the database remotely. <img width="1920" height="816" alt="Screenshot 2025-10-31 at 3 56 59 PM" src="https://github.com/user-attachments/assets/8fe7b8ea-6190-42ea-a9e0-160a7164dc5b" /> [#&#8203;1924](https://redirect.github.com/prisma/language-tools/pull/1924): previewFeatures = "" suggestion results in "\[]" value ##### Preparing for Prisma v7 Prisma v7 is almost here, and we’ve been making many of the feature in it available ahead of its release. If you haven’t been keeping your version of `prisma`, `@prisma/client` up to date, now is the time to do so before the release. Many of the changes we’ve introduced over the 6.x release cycle will become the default in v7. - Unified Prisma Config for project configuration - Move from `prisma-client-js` `prisma-client` - New `engine` and `datasource` keys in `prisma.config.ts` #### Open roles at Prisma Interested in joining Prisma? We’re growing and have several exciting opportunities across the company for developers who are passionate about building with Prisma. Explore our open positions on our [Careers page](https://www.prisma.io/careers#current) and find the role that’s right for you. #### Enterprise support Thousands of teams use Prisma and many of them already tap into our Enterprise & Agency Support Program for hands-on help with everything from schema integrations and performance tuning to security and compliance. With this program you also get priority issue triage and bug fixes, expert scalability advice, and custom training so that your Prisma-powered apps stay rock-solid at any scale. Learn more or join: <https://prisma.io/enterprise>. ### [`v6.18.0`](https://redirect.github.com/prisma/prisma/releases/tag/6.18.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/6.17.1...6.18.0) Today, we are excited to share the `6.18.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — or [follow us on X](https://pris.ly/x)!** ### Prisma ORM Prisma ORM is the most popular ORM in the TypeScript ecosystem. Today’s release brings a bunch of new bug fixes and overall improvements: - `prisma init` now creates a `prisma.config.ts` automatically When creating a new project with 6.18.0, `prisma init` will now create a `prisma.config.ts` file automatically. This prepares new applications for the future of Prisma 7. Some fields that have been historically set in the `schema.prisma` file are now able to be set in the `prisma.config.ts`, and we encourage people to migrate over to the new structure before the release of version 7, where this file will become a requirement. - Support for defining your `datasource` in `prisma.config.ts` If you’re adopting the new `prisma.config.ts` setup in your projects, version 6.18.0 brings the ability to set your datasource directly in your config file. Once this is in your config file, any datasource set in your `schema.prisma` will be ignored. To set the datasource, we also must include the new `engine` key which we can set to `"classic"` , which will be required for Prisma v7 ```tsx import { defineConfig, env } from "prisma/config"; export default defineConfig({ // The Rust-compiled schema engine engine: "classic", datasource: { url: env('DATABASE_URL'), } }); ``` - [#&#8203;28291](https://redirect.github.com/prisma/prisma/pull/28291) Support multiple Prisma instances with different providers - [#&#8203;28305](https://redirect.github.com/prisma/prisma/pull/28305) Add `env` helper function - [#&#8203;28266](https://redirect.github.com/prisma/prisma/pull/28266) Add support for `js` or `classic` as engine types in `prisma.config` - [#&#8203;28139](https://redirect.github.com/prisma/prisma/pull/28139) Map `Bytes` to `Uint8Array` depending on Typescript version ##### Preparing for Prisma v7 While it has been mentioned a few times already, many of the changes in this release are here to prepare folks for the upcoming release of Prisma v7. It’s worth repeating that these changes and the migration to `prisma.config.ts` will be required for Prisma v7, so we’re releasing this as opt-in features for developers. But come Prisma v7, they will be the new way of configuring your project. ### [Prisma Postgres](https://www.prisma.io/postgres) [Prisma Postgres](https://www.prisma.io/postgres) is our fully managed Postgres service designed with the same philosophy of great DX that has guided Prisma for close to a decade. With this release we are introducing the following improvements: ##### Database Metric in Console Inside of your database console, you can now view metrics on your database usage and interactions. You can get insights into the follow: - Total egress - Average response size - Average query duration In addition, you can also get insights into how to improve your query caching and gain better performance. #### Open roles at Prisma Interested in joining Prisma? We’re growing and have several exciting opportunities across the company for developers who are passionate about building with Prisma. Explore our open positions on our [Careers page](https://www.prisma.io/careers#current) and find the role that’s right for you. #### Enterprise support Thousands of teams use Prisma and many of them already tap into our Enterprise & Agency Support Program for hands-on help with everything from schema integrations and performance tuning to security and compliance. With this program you also get priority issue triage and bug fixes, expert scalability advice, and custom training so that your Prisma-powered apps stay rock-solid at any scale. Learn more or join: <https://prisma.io/enterprise>. ### [`v6.17.1`](https://redirect.github.com/prisma/prisma/releases/tag/6.17.1) [Compare Source](https://redirect.github.com/prisma/prisma/compare/6.17.0...6.17.1) Today, we are issuing a patch release to address a [regression in v6.17.0 that affected diffing of unsupported types](https://redirect.github.com/prisma/prisma/issues/28237), leading to unnecessary or incorrect changes when creating new migrations or running `db pull`. This update is recommended for all users who have any fields marked as `Unsupported` in their schema files. #### Changes - [prisma/prisma-engines#5633](https://redirect.github.com/prisma/prisma-engines/pull/5633) ### [`v6.17.0`](https://redirect.github.com/prisma/prisma/releases/tag/6.17.0) [Compare Source](https://redirect.github.com/prisma/prisma/compare/6.16.3...6.17.0) Today, we are excited to share the `6.17.0` stable release 🎉 **🌟 Star this repo for notifications about new releases, bug fixes & features — or [follow us on X](https://pris.ly/x)!** #### Prisma ORM Prisma ORM is the most popular ORM in the TypeScript ecosystem. Today's release brings a number of bug fixes and improvements to Prisma ORM. ##### Bug fixes and improvements - Added support for Entra ID (ActiveDirectory) authentication parameters for the MS SQL Server driver adapter. For example, you can use the `config` object to configure [DefaultAzureCredential](https://learn.microsoft.com/en-gb/azure/developer/javascript/sdk/authentication/credential-chains#use-defaultazurecredential-for-flexibility): ```ts import { PrismaMssql } from '@&#8203;prisma/adapter-mssql' import { PrismaClient } from '@&#8203;prisma/client' const config = { server: 'localhost', port: 1433, database: 'mydb', authentication: { type: 'azure-active-directory-default', }, options: { encrypt: true, }, } const adapter = new PrismaMssql(config) const prisma = new PrismaClient({ adapter }) ``` Learn more in this [PR](https://redirect.github.com/prisma/prisma/pull/28156/files#diff-351f5d894309f058776099c378e3956271f34f34c04e2b54576045b9773ab61aR61-R62). - Relaxed the support package range for `@opentelemetry/instrumentation` to be compatible with `">=0.52.0 <1"`. Learn more in this [PR](https://redirect.github.com/prisma/prisma/pull/28199/files). - Added Codex CLI detection, ensuring dangerous Prisma operations are not executed by Codex without explicit user consent. Learn more in this [PR](https://redirect.github.com/prisma/prisma/pull/28159). - Fixed JSON column handling when using a MariaDB database. Learn more in this [PR](https://redirect.github.com/prisma/prisma/pull/28211). - Restored the original behaviour of group-by aggregations where they would refer to columns with explicit table names which fixes a regression that would result in ambiguous column errors. Learn more in this [PR </details> --- ### Configuration 📅 **Schedule**: Branch creation - "on the 2nd through 5th day of the month" (UTC), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Enabled. ♻ **Rebasing**: Whenever PR is behind base branch, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about these updates again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR was generated by [Mend Renovate](https://mend.io/renovate/). View the [repository job log](https://developer.mend.io/github/JabRef/JabRefOnline). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0My40OC4xIiwidXBkYXRlZEluVmVyIjoiNDMuNDguMSIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOltdfQ==--> --------- Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Copilot <[email protected]> Co-authored-by: tobiasdiez <[email protected]> Co-authored-by: Tobias Diez <[email protected]>
1 parent c34ee59 commit 5a04f7f

File tree

9 files changed

+463
-142
lines changed

9 files changed

+463
-142
lines changed

.github/workflows/ci.yml

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -78,6 +78,7 @@ jobs:
7878

7979
env:
8080
DATABASE_URL: postgresql://postgres:postgres@localhost:5432/jabref?schema=public
81+
SHADOW_DATABASE_URL: postgresql://postgres:postgres@localhost:5432/jabref_shadow
8182
SESSION_PASSWORD: somerandompasswordNxFHaqCSPpBe6n5kRz2dru4hJ7K9bjgEtmsV8QAT3MDXcUfWGL
8283

8384
steps:
@@ -104,8 +105,14 @@ jobs:
104105
NUXT_DATABASE_URL: ${{ env.DATABASE_URL }}
105106

106107
# Check that no schema changes have been done without corresponding migration files have been added
108+
- name: Create shadow database for schema drift detection
109+
run: PGPASSWORD=postgres psql -h localhost -U postgres -c "CREATE DATABASE jabref_shadow;"
110+
107111
- name: Detect database schema drift
108-
run: pnpm prisma:migrate:diff $DATABASE_URL
112+
run: pnpm prisma:migrate:diff
113+
env:
114+
NUXT_DATABASE_URL: ${{ env.DATABASE_URL }}
115+
NUXT_SHADOW_DATABASE_URL: ${{ env.SHADOW_DATABASE_URL }}
109116

110117
- name: Build
111118
run: pnpm build

.github/workflows/deploy.yml

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -56,7 +56,9 @@ jobs:
5656

5757
- name: Reset Test database on Azure
5858
if: matrix.environment == 'Test'
59-
run: pnpm prisma:migrate:reset --force
59+
run: |
60+
pnpm prisma:migrate:reset --force
61+
pnpm prisma:seed
6062
env:
6163
NUXT_DATABASE_URL: ${{ env.DATABASE_URL }}
6264

nuxt.config.ts

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -175,7 +175,7 @@ export default defineNuxtConfig({
175175
mapperTypeSuffix: 'Model',
176176
contextType: './context#Context',
177177
mappers: {
178-
User: '@prisma/client/index.d#User',
178+
User: './database#User',
179179
Document: './documents/user.document.service#UserDocument',
180180
JournalArticle: './documents/user.document.service#UserDocument',
181181
ProceedingsArticle: './documents/user.document.service#UserDocument',

package.json

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@
1313
"generate:watch": "concurrently \"pnpm:*:generate:watch\"",
1414
"prisma:migrate:dev": "prisma migrate dev",
1515
"prisma:migrate:dev:create": "prisma migrate dev --create-only",
16-
"prisma:migrate:diff": "prisma migrate diff --exit-code --from-migrations server/database/migrations --to-schema-datamodel server/database/schema.prisma --shadow-database-url",
16+
"prisma:migrate:diff": "prisma migrate diff --exit-code --from-migrations server/database/migrations --to-schema server/database/schema.prisma",
1717
"prisma:migrate:reset": "prisma migrate reset",
1818
"prisma:migrate:deploy": "prisma migrate deploy",
1919
"prisma:migrate:status": "prisma migrate status",
@@ -52,8 +52,8 @@
5252
"@nuxtjs/tailwindcss": "7.0.0-beta.1",
5353
"@pinia/nuxt": "0.11.3",
5454
"@popperjs/core": "2.11.8",
55-
"@prisma/adapter-pg": "6.15.0",
56-
"@prisma/client": "6.15.0",
55+
"@prisma/adapter-pg": "7.4.2",
56+
"@prisma/client": "7.4.2",
5757
"@variantjs/core": "0.0.90",
5858
"@variantjs/vue": "0.0.22",
5959
"@vee-validate/zod": "4.15.1",
@@ -139,7 +139,7 @@
139139
"postinstall-postinstall": "2.1.0",
140140
"prettier": "3.8.1",
141141
"prettier-plugin-organize-imports": "4.3.0",
142-
"prisma": "6.15.0",
142+
"prisma": "7.4.2",
143143
"storybook": "10.2.13",
144144
"storybook-vue-addon": "0.6.3",
145145
"tailwindcss": "^4.1.17",
@@ -162,8 +162,8 @@
162162
"mount-vue-component": "patches/[email protected]",
163163
"@vue/apollo-util": "patches/@[email protected]",
164164
"nitropack": "patches/nitropack.patch",
165-
"prisma": "patches/prisma.patch",
166165
"@azure/static-web-apps-cli": "patches/@azure__static-web-apps-cli.patch",
166+
"prisma": "patches/prisma.patch",
167167
"@prisma/client": "patches/@prisma__client.patch"
168168
},
169169
"onlyBuiltDependencies": [

patches/@prisma__client.patch

Lines changed: 20 additions & 7 deletions
Large diffs are not rendered by default.

patches/prisma.patch

Lines changed: 4 additions & 30 deletions
Large diffs are not rendered by default.

pnpm-lock.yaml

Lines changed: 410 additions & 95 deletions
Some generated files are not rendered by default. Learn more about customizing how changed files appear on GitHub.

prisma.config.ts

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,9 +10,21 @@ import { defineConfig } from 'prisma/config'
1010
// Load environment variables from .env file
1111
config()
1212

13+
const databaseUrl = process.env.NUXT_DATABASE_URL
14+
const shadowDatabaseUrl = process.env.NUXT_SHADOW_DATABASE_URL
15+
1316
export default defineConfig({
1417
schema: path.join('server', 'database', 'schema.prisma'),
1518
migrations: {
19+
path: path.join('server', 'database', 'migrations'),
1620
seed: 'jiti ./server/database/runSeed.ts',
1721
},
22+
...(databaseUrl !== undefined
23+
? {
24+
datasource: {
25+
url: databaseUrl,
26+
...(shadowDatabaseUrl !== undefined ? { shadowDatabaseUrl } : {}),
27+
},
28+
}
29+
: {}),
1830
})

server/database/schema.prisma

Lines changed: 0 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2,12 +2,10 @@
22

33
datasource db {
44
provider = "postgresql"
5-
url = env("NUXT_DATABASE_URL")
65
}
76

87
generator client {
98
provider = "prisma-client"
10-
previewFeatures = ["queryCompiler", "driverAdapters"]
119
output = "./generated"
1210
moduleFormat = "esm"
1311
}

0 commit comments

Comments
 (0)