首页 > web前端 > js教程 > 了解使用迁移的 Prisma 工作流程

了解使用迁移的 Prisma 工作流程

王林
发布: 2024-07-18 04:31:30
原创
995 人浏览过

Entendendo o Fluxo de Trabalho do Prisma Utilizando Migrations

Prisma 是一种现代 ORM(对象关系映射),可促进 Node.js 和 TypeScript 应用程序中与数据库的交互。 Prisma 最重要的功能之一是迁移系统,它允许您保持数据库架构与应用程序的数据模型同步。在这篇文章中,我们将探索使用迁移的 Prisma 工作流程。

什么是迁移?

迁移是一种以系统化和版本化的方式控制和应用数据库模式更改的方法。它们允许您以增量和可逆的方式定义数据库的结构更改,例如创建或更改表。

Prisma 迁移工作流程

Prisma 中迁移的典型工作流程涉及以下步骤:

  1. 安装和初始配置
  2. 方案定义
  3. 创建迁移
  4. 移民申请
  5. 迁移管理

第 1 步:安装和初始配置

首先,我们需要在项目中安装Prisma并初始化:

npm install @prisma/client
npx prisma init

登录后复制

此命令创建一个包含 schema.prisma 文件的 prism 目录,我们在其中定义数据模型。

第 2 步:架构定义

在 schema.prisma 文件中,我们定义表示数据库表的模型。例如,让我们定义一个模型 User:

model User {
  id    Int     @id @default(autoincrement())
  email String  @unique
  name  String?
}

登录后复制

在这里,我们定义一个包含 id、email 和 name 列的 User 表。

第 3 步:创建迁移

定义或更改架构后,我们创建一个迁移以反映数据库中的这些更改:

npx prisma migrate dev --name init

登录后复制

migrate dev 命令创建一个新的迁移并将更改应用到数据库。 --name 参数允许您为迁移指定一个描述性名称,例如上面示例中的 init。

第四步:移民申请

当我们使用 migrate dev 命令时,迁移会自动应用于数据库。这确保数据库始终与 schema.prisma 中定义的数据模型同步。

如果要在生产环境中应用迁移,请使用命令:

npx prisma migrate deploy

登录后复制

此命令将所有挂起的迁移应用到生产数据库。

第5步:迁移管理

Prisma 保留应用于数据库的所有迁移的历史记录。这对于跟踪更改并在必要时恢复迁移非常有用。要查看迁移历史,您可以使用:

npx prisma migrate status

登录后复制

此命令显示迁移的当前状态,包括哪些迁移已应用,哪些迁移正在等待。

实际例子

让我们看一个实际示例,了解如何向用户模型添加新字段并为此更改创建迁移。

  1. 将字段添加到 schema.prisma 中的用户模型:

    model User {
      id        Int     @id @default(autoincrement())
      email     String  @unique
      name      String?
      birthdate DateTime?
    }
    
    
    登录后复制
  2. 创建新迁移:

    npx prisma migrate dev --name add-birthdate-to-user
    
    
    登录后复制
  3. 应用迁移:

    migrate dev 命令已经将迁移应用到数据库。现在数据库将在用户表中添加新的生日字段。

  4. 检查迁移状态:

    npx prisma migrate status
    
    
    登录后复制

    此命令将显示添加出生日期到用户迁移已成功应用。

结论

Prisma 使用迁移的工作流程是管理数据库架构更改的高效且安全的方法。通过一系列清晰的步骤——定义模式、创建迁移、应用更改和管理迁移历史记录——可以使数据库与应用程序的数据模型保持同步,从而促进软件的开发和维护。

使用 Prisma,您不仅可以简化数据库管理,还可以获得一个强大的工具来确保所有更改都是可追踪和可逆的,从而有助于实现更强大和敏捷的开发流程。

以上是了解使用迁移的 Prisma 工作流程的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板