首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Prisma ORM 又双叒叕发布新版本了!

Prisma ORM 又双叒叕发布新版本了!

作者头像
萌萌哒草头将军
发布2025-08-04 11:16:01
发布2025-08-04 11:16:01
22100
代码可运行
举报
文章被收录于专栏:前端框架前端框架
运行总次数:0
代码可运行

前言

Prisma ORM 又发布新版本了,这一版本不仅提升了 Prisma 的核心功能,还通过新的 CI/CD 工具和用户界面改进,为开发者提供了更高效的开发体验。以下是主要更新的详细介绍。

往期精彩推荐

正文

配置和模式增强
  • 使用 prisma.config.ts 进行 TypeScript 原生配置

Prisma ORM 现在支持通过 TypeScript 文件 prisma.config.ts 配置项目中的各种方面,包括模式、迁移、SQL 视图、TypedSQL、种子命令、外部管理表和驱动适配器!

代码语言:javascript
代码运行次数:0
运行
复制
import path from "node:path";
import { defineConfig } from "prisma/config";

export default defineConfig({
  schema: path.join("db", "schema.prisma"),
  migrations: {
    path: path.join("db", "migrations"),
    seed: "tsx db/seed.ts",
  },
});
  • 多模式支持

现在,您可以将数据库表组织到多个模式中,这一功能已正式发布,适用于 PostgreSQLSQL Server 等数据库。通过在 Prisma 模式中使用 @@schema 属性。

代码语言:javascript
代码运行次数:0
运行
复制
datasource db {
  provider = "postgresql"
  url      = env("DATABASE_URL")
  schemas  = ["base", "shop"]
}

model User {
  id     Int     @id
  orders Order[]

  @@schema("base")
}

model Order {
  id      Int  @id
  user    User @relation(fields: [userId], references: [id])
  userId  Int

  @@schema("shop")
}

由于 mysql 和 sql lite 的命名空间和模式概念不同,所以该功能暂不支持 mysql 和 sql lite !

  • SQL 视图支持(预览版)

Prisma ORM 现在允许您直接在模式中使用 SQL 视图。然而,这一功能目前仍处于预览阶段,存在一些限制。例如,开发者无法在视图上定义 @id@index@unique,并且某些操作如 findUnique、写入操作、游标分页、隐式排序和关系查询是禁用的!

  • 外部管理表

一个新功能,允许您将外部管理的表包含在 Prisma Client 中。这些表将被 Prisma Migrate 忽略,使其适合于需要查询非 Prisma 管理表的数据的场景,例如 Supabase 的用户表。对这些表的配置可以在 prisma.config.ts 中完成,为开发者提供了更大的灵活性。

代码语言:javascript
代码运行次数:0
运行
复制
// prisma.config.ts
export default defineConfig({
  tables: {
    external: [
      "users",
    ]
  },
  ...
})
Postgres 特定功能
  • Prisma Postgres 的新管理 API

引入了一个新的 REST API,用于管理 Prisma Postgres 实例。该 API 允许您创建和删除实例、管理连接字符串,并直接从 Prisma Console 自动化工作流。

代码语言:javascript
代码运行次数:0
运行
复制
// Set HTTP headers (auth via a dedicated service token)
const headers = {
Authorization: `Bearer ${SERVICE_TOKEN}`, // get your token in Prisma Console
'Content-Type': 'application/json',
};

// Create a new project
const projectName = `demo-project-${Date.now()}`;
const region = 'us-east-1';

const createProjectRes = await axios.post(
`https://api.prisma.io/v1/projects`,
  { name: projectName, region },
  { headers }
);

const project = createProjectRes.data;
const projectId = project.id || (project.data && project.data.id);

console.log('Created project and databases: \\n', project);
开发和部署工具
  • Prisma Postgres 的 CI/CD GitHub Actions

为了更好地整合到 CI/CD 管道中,Prisma 引入了两个 GitHub Actions 模板!

GitHub Actions
GitHub Actions

GitHub Actions

  • 使用 npx create-db 快速启动 Postgres

使用 npx create-db 命令可以在几秒钟内启动一个 Postgres 数据库实例,无需身份验证,如果 24 小时未认领,将自动删除。开发者可以通过 Prisma Console 认领它以进行持久使用!

npx create-db
npx create-db

npx create-db

  • Prisma Console UI 的重新设计

Prisma Console 已经进行了导航改版,使创建新项目、在现有项目之间切换以及访问设置变得更简单,减少了操作复杂性。

Prisma Console UI 的重新设计
Prisma Console UI 的重新设计

Prisma Console UI 的重新设计

最后

不得不说,最近几个新版本通过增强的配置选项、对高级 Postgres 功能的支持,以及新的工作流工具,都为开发者提供了舒适的开发体验!

今天的分享就这些了,感谢大家的阅读,如果文章中存在错误的地方欢迎指正!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2025-07-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 萌萌哒草头将军 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
    • 往期精彩推荐
  • 正文
    • 配置和模式增强
    • Postgres 特定功能
    • 开发和部署工具
  • 最后
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档