.NET使用一行命令轻松生成EF Core项目框架

dotnet ef是Entity Framework Core(EF Core)的一个命令行工具,用于管理EF Core应用程序的数据库和代码。除了提供管理数据库的命令之外,dotnet ef还可以生成和管理实体和上下文代码。本文将介绍如何使用dotnet ef动态生成代码。

一、环境准备

1、项目准备

用vs2022新建一个.NET6的asp.net core mvc项目,然后按照:工具->Nuget包管理器->nuget管理解决方案包。安装一些nuget包

Microsoft.EntityFrameworkCore.Design
Microsoft.EntityFrameworkCore.SqlServer
Microsoft.EntityFrameworkCore.Tools

或者用nuget命令安装

Install-Package Microsoft.EntityFrameworkCore.Design
Install-Package Microsoft.EntityFrameworkCore.SqlServer
Install-Package Microsoft.EntityFrameworkCore.Tools

2、安装dotnet ef

工具->Nuget包管理器->程序包管理控制台

执行 dotnet tool install --global dotnet-ef --version x.x.x  注:这里的包版本要和上面的版本一致,这个包直接通过右键管理程序nuget包方式安装会报冲突错误,谁知道原因可以说一下。

安装成功标志

图片

二、生成代码

在vs2022中点击项目右键,选择"在终端中打开"。在命令行中运行以下命令,生成实体类,模型的代码:

dotnet ef dbcontext scaffold "Data Source=.;Initial Catalog=Wan;Persist Security Info=True;User ID=sa;Password=654321;TrustServerCertificate=true" Micros
oft.EntityFrameworkCore.SqlServer --output-dir Entities --context NewDbContext

上面脚本解释:

scaffold后面是数据库链接字符串,--output-dir参数指定输出目录,--force参数表示强制覆盖生成的文件。运行这个命令将生成一个或多个实体类的代码。--context参数为指定上下文类的名称。

图片

亦可以用以下命令一键生成。

dotnet ef dbcontext scaffold "Data Source=.;Initial Catalog=Wan;Persist Security Info=True;User ID=sa;Password=654321;TrustServerCertificate=true" Microsoft.EntityFrameworkCore.SqlServer  -o Models

-o Models的意思是将生成的实体类文件输出到名为Models的文件夹中。这里没有指定上下文,默认上下文的文件名为数据库名称。

效果如下:

图片

片段代码如下:

图片

小插曲:

在生成代码时遇到如下问题:

A connection was successfully established with the server, but then an error occurred during the login process. (provider: SSL Provider, error: 0 - 证书链是由不受信任的颁发机构颁发的。)

解决方法直接在“数据库连接字符串最后面”增加证书信任的配置。;TrustServerCertificate=true。

结语

使用dotnet ef可以轻松地生成实体和上下文类的代码。在EF Core应用程序中,这是一个非常方便的工具,因为它可以减少手动编写代码的时间,并提供了基本的代码框架,使您可以专注于业务逻辑的实现。本文介绍了它的实现步骤,仅供参考,希望本文对你有所收获,同时欢迎留言和吐槽。

****参考:微软官网文档

来源公众号:DotNet开发跳槽

原文链接:https://www.cnblogs.com/xbhp/p/17358602.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:.NET使用一行命令轻松生成EF Core项目框架 - Python技术站

(0)
上一篇 2023年5月5日
下一篇 2023年5月5日

相关文章

  • 带你一文了解C#中的Expression

    带你一文了解C#中的Expression 什么是Expression 在C#中,Expression是一个抽象类,它代表了一个包含单个值、操作符、变量、方法调用或属性访问等逻辑的树形结构。 Expression对象可以被应用于以程序方式表示代码逻辑的情况,通常被用于了解程序上下文、编译代码或构建API。具体来说,Expression很常用于Lambda表达式…

    C# 2023年6月1日
    00
  • C# 读写编辑INI文件的操作

    C# 读写编辑INI文件的操作可以通过以下步骤完成: 步骤一:引入ini文件解析库 由于C#标准库中并未提供对ini文件的解析和读写操作,因此我们需要引入第三方库。比较常用的有iniFile和INIParser,这里以INIParser为例进行说明。首先需要在项目中安装INIParser库,可以通过NuGet包管理器直接安装。 步骤二:读取INI文件 读取I…

    C# 2023年6月1日
    00
  • ASP.NET Core基础之启动设置

    ASP.NET Core基础之启动设置 ASP.NET Core是一个跨平台的开源Web框架,它可以在Windows、Linux和macOS上运行。在ASP.NET Core应用程序中,启动设置是非常重要的,因为它们决定了应用程序的行为和性能。本文将介绍ASP.NET Core应用程序的启动设置,并提供一些示例来说明如何使用它们。 启动设置 ASP.NET …

    C# 2023年5月17日
    00
  • .NET 6实现滑动验证码的示例详解

    以下是关于“.NET6实现滑动验证码的示例详解”的完整攻略: 1. 什么是滑动验证码? 滑动验证码是一种常见的验证码形式,它要求用户在一个滑块上滑动,以证明他们是真正的人类用户,而不是机器人或恶意软件。 2. 如何使用.NET6实现滑动验证码? 在.NET6中,可以使用ASP.NET Core MVC和JavaScript来实现滑动验证码。可以按照以下步骤操…

    C# 2023年5月12日
    00
  • C# 手写识别方案整理

    书写识别,网上的大佬们都有输出。 书写识别存在的2个问题: 直接拿官网的案例(将 Windows Ink 笔划识别为文本和形状 – Windows apps | Microsoft Learn),会发现输出准确度不高。 另外如果书写过快,词组识别也是个问题,毕竟无法准确分割字之间的笔迹。 我结合之前开发经验,整理下书写识别比较完善的方案。 单个字的识别方案:…

    C# 2023年5月5日
    00
  • 关于C#操作文件路径(Directory)的常用静态方法详解

    关于C#操作文件路径(Directory)的常用静态方法详解 Directory类的简介 在C#中,Directory类提供了用于操作文件夹和文件路径的静态方法。它通过一系列的静态方法,可以实现对于文件夹以及文件路径的各种操作。常用的静态方法有以下几种: Directory.Exists(string path):判断某个路径是否存在 Directory.C…

    C# 2023年5月15日
    00
  • C#关机小程序源码

    对于“C#关机小程序源码”的完整攻略,我将从以下几个方面进行详细讲解: 实现功能及设计思路 编写代码及说明 示例说明 1. 实现功能及设计思路 本小程序的主要功能为实现计算机关机,设计思路为利用C#的系统调用函数,调用Windows的API函数实现计算机的关机操作。 具体实现步骤如下: 创建一个Windows窗口应用程序 在程序中添加一个按钮控件,用于触发计…

    C# 2023年6月1日
    00
  • C# 操作Excel代码总结

    下面就为您详细讲解“C# 操作Excel代码总结”的完整攻略。 一、前言 在日常开发中,Excel 是我们经常应用的工具。在 C# 中,操作 Excel 也是一个常见的需求。本文就通过两个示例,来总结一下 C# 中操作 Excel 的代码实现过程。 二、基本环境 在操作 Excel 的过程中,我们需要引入以下命名空间: using Microsoft.Off…

    C# 2023年6月7日
    00
合作推广
合作推广
分享本页
返回顶部