【Prisma】如何修复(重建)已经损坏的迁移历史?

当 migrations 历史已经损坏,但是数据库的数据还是完好的,这时简单的方法是删除迁移历史记录,以数据库内容重建迁移历史,也就是以当前数据库的状态重建基线,具体如下。

实际情况是,当你应用 migrate 命令时报错,显示迁移历史记录丢失。

这种情况发生的原因是:你的数据库中存在一个名为 _prisma_migrations 的表,记录了过去所有的迁移历史(那几十个 2025xxxx 的记录),但你本地的 prisma/migrations 文件夹为空。Prisma 发现数据库记录的迁移在本地找不到,因此认为发生了"漂移(Drift)"。

千万不要运行 prisma migrate reset,否则会清空所有数据。

按照以下步骤通过"基线化(Baselining)"来恢复迁移功能:

第一步:清理数据库中的迁移记录

由于你本地的迁移文件已经丢失,且你想重新开始,我们需要让数据库"忘记"之前的迁移历史。

连接到你的数据库(使用 pgAdmin, TablePlus 或命令行),执行以下 SQL:

sql 复制代码
-- 删除所有旧的迁移记录,这样 Prisma 就会认为这是一个新起点
TRUNCATE TABLE _prisma_migrations;

第二步:创建初始迁移文件(基线)

现在我们要根据当前的 schema.prisma 创建一个新的"起始"迁移文件,但不立即执行它(因为表已经在数据库里了)。

  1. 创建迁移文件夹(如果不存在):

    bash 复制代码
    mkdir -p prisma/migrations/0_init
  2. 使用 prisma migrate diff 生成当前 schema 的全量 SQL:

    bash 复制代码
    npx prisma migrate diff \
      --from-empty \
      --to-schema-datamodel prisma/schema.prisma \
      --script > prisma/migrations/0_init/migration.sql

    这一步会把当前的模型定义生成为一个完整的 migration.sql 文件。

第三步:标记该迁移已完成(关键)

我们需要告诉 Prisma:"这个 0_init 迁移已经应用过了,你不需要再往数据库里跑 SQL 了"。

执行以下命令:

bash 复制代码
npx prisma migrate resolve --applied 0_init

第四步:同步并验证

现在你的本地文件(0_init)和数据库记录(_prisma_migrations 表里的一条记录)就同步了。

尝试运行:

bash 复制代码
npx prisma migrate dev

结果预测:

  • 如果你的 schema.prisma 和 数据库结构 完全一致 ,Prisma 会提示 Already in sync
  • 如果你有细微改动,Prisma 会提示你创建一个新的迁移。

常见问题排查

1. 如果执行 migrate resolve 报错找不到文件?

确保目录结构如下:

text 复制代码
prisma/
  schema.prisma
  migrations/
    0_init/
      migration.sql

2. 以后改了 schema 怎么办?

现在迁移功能已经恢复了。以后只需正常运行:

bash 复制代码
npx prisma migrate dev --name add_new_field

3. 为什么不直接用 migrate dev --create-only

因为当数据库中存在 _prisma_migrations 记录而本地没有文件时,Prisma 的安全机制会强制要求 reset。手动清空该表并 resolve 是绕过此机制且保护数据的标准做法。

建议: 修复完成后,务必将新的 migrations 文件夹提交到 Git 仓库,防止再次丢失。

相关推荐
颂love8 小时前
MySQL的执行流程
android·数据库·mysql
程序leo源8 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
这个DBA有点耶8 小时前
COUNT进阶:超大表的近似计数与HyperLogLog
数据库·sql·程序人生·学习方法·dba·改行学it
武子康9 小时前
调查研究-138 全球机器人产业深度调研报告【01 篇】:市场规模、竞争格局与商业化成熟 2026
服务器·数据库·ai·chatgpt·机器人·具身智能
zhojiew9 小时前
在本地PostgreSQL使用pgvector构建生成式 AI 应用的实践
数据库·人工智能·postgresql
Yushan Bai9 小时前
EXADATA X5数据库一体机节点login: failure forking: Cannot allocate memory问题处理
数据库·oracle·vr
KaMeidebaby9 小时前
卡梅德生物技术快报|噬菌体肽库展示技术构建 Mhp168‑Hsp70 定向随机肽库:流程、质控与数据结果
前端·数据库·其他·百度·新浪微博
SelectDB10 小时前
Agent 时代,为什么传统的可观测方案不适用了?
大数据·数据库·数据分析
snowfoootball10 小时前
解决低版本navicat连接PostgreSQl的不兼容报错问题
数据库·postgresql