跳至主要内容

不支持的数据库功能

Prisma Migrate 使用 Prisma schema 来确定要在数据库中创建哪些功能。然而,一些数据库功能无法在 Prisma schema 中表示,包括但不限于:

  • 存储过程
  • 触发器
  • 视图
  • 部分索引

要向数据库添加不受支持的功能,您必须在应用迁移之前定制迁移以包含该功能。

提示

Prisma schema 能够表示不支持的字段类型原生数据库函数

警告

本指南不适用于 MongoDB
对于 MongoDB,使用 db push 而非 migrate dev

定制迁移以包含不支持的功能

要定制迁移以包含不支持的功能:

  1. 使用 --create-only 标志生成新的迁移,但不应用它

    npx prisma migrate dev --create-only
  2. 打开生成的 migration.sql 文件并添加不支持的功能 - 例如,部分索引

    CREATE UNIQUE INDEX tests_success_constraint
    ON posts (subject, target)
    WHERE success;
  3. 应用迁移

    npx prisma migrate dev
  4. 将修改后的迁移提交到源代码控制。