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

yizhihongxing

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日

相关文章

  • MongoDB对Document(文档)的插入、删除及更新

    下面是MongoDB对Document的插入、删除及更新的完整攻略。 插入Document MongoDB插入Document的语法为: db.collection.insert(document) 其中,db.collection是指要插入Document的collection名称,document是一条Document。 在插入Document时,如果该…

    C# 2023年5月15日
    00
  • C#深拷贝方法探究及性能比较(多种深拷贝)

    C#深拷贝方法探究及性能比较(多种深拷贝) 什么是深拷贝 在 C# 的开发中,经常需要复制一份对象,以便于对该对象进行修改而不影响原来的对象。浅拷贝(shallow copy)只是简单地复制了一份对象的引用,而不是实际的对象,原始对象和副本对象共享引用类型的成员变量。而深拷贝(deep copy)则会创建一份新的对象,并复制原始对象所有的成员变量,包括引用类…

    C# 2023年5月31日
    00
  • Java和C#下的参数验证方法

    下面是Java和C#下的参数验证方法的完整攻略: Java下的参数验证方法 在Java中,参数验证通常使用JSR 303/349 Bean Validation规范的注解实现。通过在实体类的属性上标注对应的注解,可以对参数进行各种验证,比如非空、长度、格式等等。这些注解在Java Bean Validation API中已经定义好了。 下面是示例代码: im…

    C# 2023年6月6日
    00
  • 通过C#实现自动售货机接口

    通过C#实现自动售货机接口的完整攻略如下: 一、了解接口 在开始编写自动售货机接口之前,需要先了解什么是接口。接口(Interface)是一种抽象的类型,它定义了让其他程序集(Assembly)访问该程序集的功能。通过接口,可以使一个类实现多个不相关的类型。 二、创建项目 打开Visual Studio,创建一个新的C#控制台应用程序项目; 在解决方案资源管…

    C# 2023年6月1日
    00
  • C#匹配中文字符串的4种正则表达式分享

    当我们需要在C#中匹配中文字符串时,我们通常会使用正则表达式进行匹配。下面是匹配中文字符串的4种C#正则表达式。 1. 匹配中文字符的Unicode编码范围 string pattern = @"[\u4e00-\u9fa5]"; Regex regex = new Regex(pattern); MatchCollection matc…

    C# 2023年6月8日
    00
  • .Net Core 实现图片验证码的实现示例

    下面我会为您详细讲解如何实现“.Net Core 实现图片验证码的实现示例”。 一、需求分析 在实现图片验证码之前,我们需要分析一下实现的需求,常见需求包括:生成图片验证码,并将验证码存储到Session或数据库中,校验用户输入的验证码是否正确。在本例中,我们将采用生成图片验证码和校验用户输入的验证码是否正确这两个功能。 二、Bulid项目 我们首先需要创建…

    C# 2023年6月3日
    00
  • C# DataTable数据遍历优化详解

    当处理大数据量的DataTable时,常常需要考虑优化数据遍历的性能,这里将介绍一些优化技巧来提高C#的DataTable遍历速度。 1. 使用索引来提高DataTable遍历性能 使用索引是数据检索的一种高效方式。在DataTable中使用PrimaryKey,可以基于每个列的唯一值来创建索引。通过使用PrimaryKey,可以遍历DataRow的速度被大…

    C# 2023年5月31日
    00
  • 灵活使用asp.net中的gridview控件

    使用ASP.NET中的GridView控件可以快速实现数据的呈现和管理。下面是灵活使用GridView控件的攻略: 1.绑定数据源 GridView控件的数据源可以是DataTable、DataSet、Array等多种类型的对象。以下是以DataTable作为数据源的示例: protected void Page_Load(object sender, Ev…

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