news 2026/3/1 17:34:12

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Prisma】如何修复(重建)已经损坏的迁移历史?

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

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

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

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

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

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

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

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

-- 删除所有旧的迁移记录,这样 Prisma 就会认为这是一个新起点TRUNCATETABLE_prisma_migrations;

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

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

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

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

    npx prisma migratediff\--from-empty\--to-schema-datamodel prisma/schema.prisma\--script>prisma/migrations/0_init/migration.sql

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

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

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

执行以下命令:

npx prisma migrate resolve --applied 0_init

第四步:同步并验证

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

尝试运行:

npx prisma migrate dev

结果预测:

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

常见问题排查

1. 如果执行migrate resolve报错找不到文件?
确保目录结构如下:

prisma/ schema.prisma migrations/ 0_init/ migration.sql

2. 以后改了 schema 怎么办?
现在迁移功能已经恢复了。以后只需正常运行:

npx prisma migrate dev --name add_new_field

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

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/27 11:45:33

4、Windows 10 使用指南:系统设置、网络连接与账户创建

Windows 10 使用指南:系统设置、网络连接与账户创建 1. 检查重要更新 在使用 Windows 10 系统时,及时更新系统是保障系统性能和安全的重要步骤。以下是检查更新的具体操作: 1. 打开“设置”屏幕,选择“更新和安全”选项。若不清楚如何进入“设置”屏幕,可参考相关指引。…

作者头像 李华
网站建设 2026/2/27 4:56:07

5、Windows 10 账户管理与桌面使用全攻略

Windows 10 账户管理与桌面使用全攻略 在使用 Windows 10 系统时,账户管理和桌面操作是非常重要的两个方面。合理管理账户能保障个人隐私和数据安全,而熟练运用桌面功能则能提高工作和娱乐的效率。下面将详细介绍 Windows 10 中账户的创建、切换、密码管理以及桌面的基本操作…

作者头像 李华
网站建设 2026/2/27 5:39:20

16、Windows 10 文件备份、恢复与电脑重置全攻略

Windows 10 文件备份、恢复与电脑重置全攻略 在使用 Windows 10 系统时,文件备份、恢复以及电脑重置是非常重要的操作。它们能帮助我们保护数据安全,解决电脑出现的各种问题。下面将详细介绍这些操作的具体步骤和相关注意事项。 开启文件历史记录功能 文件历史记录功能可以…

作者头像 李华
网站建设 2026/2/27 1:05:22

MySQL的安装与卸载

一、MySQL的安装 1.1 下载 点开链接:https://dev.mysql.com/downloads/mysql/ 点击Download 就可以下载对应的安装包了。 1.2 解压 下载完成后我们得到的是一个压缩包,将其解压,我们就可以得到MySQL 8.0.44 的软件本体了(就是一个文件夹…

作者头像 李华
网站建设 2026/2/28 2:12:58

【读论文】2021美赛D题 O奖(3)2121604

基于影响者网络与余弦相似度的音乐演变探索 摘要 为理解音乐的演变过程,本研究结合网络科学、余弦相似度、物理学中的冷却模型与引力模型以及其他统计方法,探究音乐如何通过艺术家和流派间的影响力实现演变。 首先,构建有向影响者网络&…

作者头像 李华
网站建设 2026/2/27 18:26:13

Step3:321B参数高效多模态推理模型

Step3作为一款拥有3210亿总参数、380亿激活参数的混合专家(Mixture-of-Experts)架构多模态模型,通过创新的注意力机制与系统设计,重新定义了大模型在视觉-语言推理任务中的效率标准。 【免费下载链接】step3 项目地址: https:/…

作者头像 李华