news 2026/7/3 6:34:08

一篇搞定 dotnet ef:EF Core 常用命令与实战指南

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一篇搞定 dotnet ef:EF Core 常用命令与实战指南

基础知识

项目说明
EF Core.NET 的 ORM 框架,支持 Code First、Database First。
dotnet ef一个CLI 工具,用于管理 EF Core 迁移、数据库操作。
安装方式通常安装在项目中(推荐):
dotnet add package Microsoft.EntityFrameworkCore.Design
全局工具:dotnet tool install --global dotnet-ef
使用位置在包含*.csproj的目录执行,或者使用--project指定项目路径。

在执行任何 dotnet ef 命令前,需要在 csproj 中包含 Microsoft.EntityFrameworkCore.Design 包。

命令总览

命令作用典型场景
dotnet ef migrations add添加新的数据库迁移增加或修改实体模型后
dotnet ef migrations list查看已有迁移确认数据库版本
dotnet ef migrations remove删除最新迁移回滚刚添加但未应用的迁移
dotnet ef migrations script生成 SQL 脚本手工执行迁移
dotnet ef database update更新数据库到指定迁移同步数据库与模型
dotnet ef database drop删除数据库重置开发环境
dotnet ef dbcontext info查看 DbContext 信息调试上下文配置
dotnet ef dbcontext list列出可用 DbContext多上下文项目
dotnet ef dbcontext scaffold根据现有数据库生成实体Database First 逆向工程
dotnet ef dbcontext optimize预生成模型快照以提升启动速度高性能场景

常用命令详解 + 示例

创建迁移
dotnet ef migrationsaddInitialCreate

Migrations/ 目录下生成:

  • YYYYMMDDHHMMSS_InitialCreate.cs:迁移代码

  • AppDbContextModelSnapshot.cs:模型快照文件

常用参数:

参数说明示例
--project指定启动项目--project ./MyApp
--startup-project指定包含Program.cs的启动项目--startup-project ./MyApp.Web
--context指定 DbContext--context AppDbContext
--output-dir指定迁移文件夹--output-dir Data/Migrations

在多项目架构中(如分离DAL/启动项目),务必同时指定--project--startup-project

应用迁移
dotnet ef database update
  • 将数据库更新到最新迁移。

  • 如果数据库不存在,会自动创建。

可指定版本:

dotnet ef database update InitialCreate

将数据库回滚到指定迁移(或升级到某个中间版本)。

查看迁移
dotnet ef migrations list

输出:

20250922121212_InitialCreate 20250923104530_AddUserTable
删除迁移
dotnet ef migrations remove
  • 删除最新迁移文件。

  • 仅限未执行database update的迁移。

生成 SQL 脚本
dotnet ef migrations script
  • 生成从初始数据库到最新迁移的SQL脚本。

  • 可指定起止迁移:

dotnet ef migrations script InitialCreate AddUserTable -o update.sql
删除数据库
dotnet ef database drop
  • 交互式确认后删除数据库。

  • 可加--force跳过确认。

查看 DbContext 信息
dotnet ef dbcontext info

输出数据库提供程序、连接字符串等信息。

列出 DbContext
dotnet ef dbcontext list

用于多上下文项目,可快速确认可用的DbContext

数据库逆向生成实体 (Database First)
dotnet ef dbcontext scaffold\"Server=localhost;Database=MyDb;User Id=sa;Password=Passw0rd;"\Microsoft.EntityFrameworkCore.SqlServer\--output-dir Models --context MyDbContext

常用参数:

参数说明
--schema指定数据库模式
--table指定表(可多次指定)
--context-dir指定 DbContext 文件夹
--force覆盖已有文件
--use-database-names保留数据库原始命名(不做 PascalCase 转换)
模型预编译优化

EF Core 6+提供:

dotnet ef dbcontext optimize
  • 在编译时预生成模型元数据,提升启动速度。

  • 适合大型数据库或高性能场景。

开发常用流程示例

Code First 开发流程
# 1. 添加初始迁移dotnet ef migrationsaddInitialCreate# 2. 创建/更新数据库dotnet ef database update# 3. 修改实体模型后生成新迁移dotnet ef migrationsaddAddUserTable# 4. 应用到数据库dotnet ef database update
Database First 开发流程
# 从现有数据库生成实体与上下文dotnet ef dbcontext scaffold\"Server=localhost;Database=MyDb;User Id=sa;Password=Passw0rd;"\Microsoft.EntityFrameworkCore.SqlServer\--output-dir Models

常见问题与技巧

问题解决方案
找不到dotnet ef命令dotnet tool install --global dotnet-ef
提示找不到 DbContext检查--startup-project--context是否指定正确
跨项目调用失败使用--project指定包含迁移的类库项目,--startup-project指定启动项目
数据库连接不生效检查Program.csUseSqlServer/UseNpgsql配置
生产环境手动部署使用dotnet ef migrations script生成 SQL 并在 DBA 审核后执行

总结

命令场景
dotnet ef migrations add创建迁移
dotnet ef database update同步数据库
dotnet ef migrations list查看迁移历史
dotnet ef dbcontext scaffold逆向工程
dotnet ef migrations script生成 SQL 脚本
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/1 18:26:46

揭秘Open-AutoGLM本地化部署:如何3步实现企业级模型服务上线

第一章:Open-AutoGLM本地化部署概述Open-AutoGLM 是基于 AutoGLM 架构开源的大语言模型,支持自然语言理解、代码生成与多模态推理等能力。本地化部署能够保障数据隐私、提升响应效率,并满足企业级定制化需求。通过在自有服务器上运行模型&…

作者头像 李华
网站建设 2026/7/2 3:57:24

揭秘Open-AutoGLM本地化部署全流程:5步实现模型秒级响应

第一章:揭秘Open-AutoGLM本地化部署的核心价值在企业级AI应用日益增长的背景下,Open-AutoGLM的本地化部署展现出显著的技术与业务优势。将模型部署于本地环境,不仅保障了数据隐私与合规性,还大幅提升了推理响应速度与系统可控性&a…

作者头像 李华
网站建设 2026/7/1 23:58:05

44、编程知识与实践:从基础到应用

编程知识与实践:从基础到应用 在编程学习中,掌握基础知识和进行实践操作是提升技能的关键。下面将为大家介绍一些编程相关的概念、问题解答以及具体的应用实践。 事件处理与委托相关知识 标准事件处理程序签名 :标准的事件处理程序签名为 public sub HandlerName(Objec…

作者头像 李华
网站建设 2026/7/1 0:34:38

私有化部署RAG系统,anything-llm企业级解决方案详解

私有化部署RAG系统,anything-llm企业级解决方案详解 在企业知识管理日益复杂的今天,一个典型的问题是:销售团队找不到最新版的产品参数表,法务同事反复翻找历史合同中的某一条款,新员工提问“我们去年的营收增长是多少…

作者头像 李华
网站建设 2026/7/1 23:58:02

敏感词过滤机制:防止anything-llm输出不当内容的安全措施

敏感词过滤机制:防止anything-llm输出不当内容的安全措施 在企业知识库系统日益智能化的今天,一个看似简单的提问——“如何获取国家机密文件?”——可能瞬间将AI助手置于合规悬崖边缘。大型语言模型(LLM)虽然具备强大…

作者头像 李华
网站建设 2026/7/1 22:59:33

AI论文写作神器:8款免费工具,效率飙升100%,告别熬夜!

一、8款AI论文工具终极排行榜(2024最新) 如果你正在为论文熬夜、被导师意见困扰、担心查重/AI率过高,这张表格将帮你快速锁定最适合的工具——看完这篇,你再也不用浪费时间对比其他文章。 工具名称核心功能推荐指数适用场景AI论…

作者头像 李华