本篇随笔介绍如何使用.NET Core+EF Core创建Web应用程序

首先借用官网的话简单介绍一下ASP.NET Core

ASP.NET Core 是一个跨平台的高性能开源框架,用于生成基于云且连接 Internet 的新式应用程序。 使用 ASP.NET Core可以:

  • 创建 Web 应用程序和服务、IoT 应用和移动后端。
  • 在 Windows、macOS 和 Linux 上使用喜爱的开发工具。
  • 部署到云或本地。
  • 在 .NET Core 或 .NET Framework上运行。
我的开发工具:Visual Studio2017、SqlServer2012
我的开发环境:.NET Core2.2

接下来介绍使用Visual Studio2017创建Web项目,步骤如下:

1、选择.NET Core→ASP.NET Core Web应用程序,点击确定

2、选择.NET Core、ASP.NET Core2.2,选择Web应用程序(模型视图控制器)即MVC,暂时不进行身份验证,点击确定

得到如下解决方案:

3、使用工具→NuGet包管理→程序包管理控制台添加EF依赖

在NuGet官网找到Microsoft.EntityFrameworkCore包

网址:https://www.nuget.org/packages/Microsoft.EntityFrameworkCore

然后在程序包管理控制台中输入  Install-Package Microsoft.EntityFrameworkCore -Version 2.2.4 点击回车

在依赖项NuGet中出现Microsoft.EntityFrameworkCore(2.2.4)包说明添加EF依赖成功。

也可直接在项目工程文件(*.csproj)中添加如下代码达到添加EF依赖的目的

<ItemGroup>
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="2.2.4" />
</ItemGroup>

4、创建数据库上下文和模型类

在解决方案下新建.NET Core类库DAL(同样记得添加EF依赖),在DAL中新建数据库上下文(MyDataContext)和模型类(UserInfo),代码如下:

using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema; namespace DAL
{
public class UserInfo
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
[Required(ErrorMessage = "不能为空")]
[Display(Name = "用户ID")]
public int UId { get; set; } [Required(ErrorMessage = "不能为空")]
[Display(Name = "用户名")]
public string UName { get; set; } [Required(ErrorMessage = "不能为空")]
[StringLength(, ErrorMessage = "长度不能超过50")]
[Display(Name = "密码")]
public string UPws { get; set; } [Required(ErrorMessage = "不能为空")]
[RegularExpression(@"[A-Za-z0-9._%+-]+@[A-Za-z0-9]+\.[A-Za-z]{2,4}", ErrorMessage = "邮箱格式错误")]
[Display(Name = "邮箱")]
public string UEmail { get; set; } [Required(ErrorMessage = "不能为空")]
[StringLength(, ErrorMessage = "长度不能超过11")]
[Display(Name = "联系方式")]
public string UTel { get; set; }
}
}
using Microsoft.EntityFrameworkCore;

namespace DAL
{
public class MyDataContext : DbContext
{
public MyDataContext(DbContextOptions<MyDataContext> options) : base(options) { } public DbSet<UserInfo> UserInfo { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
base.OnConfiguring(optionsBuilder);
} protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
}
}
}

备注:数据库上下文是为数据模型协调 Entity Framework 功能的主类 。 此类由 Microsoft.EntityFrameworkCore.DbContext 类派生而来。

5、在Startup.cs中注册数据库上下文

在 ASP.NET Core 中,服务(如数据库上下文)必须向依赖关系注入(DI)容器进行注册。 该容器向控制器提供服务。

在Startup.cs的ConfigureServices()方法中添加如下代码:

var connection = "Data Source=.;Initial Catalog=TestDb;User Id=sa;Password=svse;";
services.AddDbContext<MyDataContext>(options =>
options.UseSqlServer(connection, b => b.MigrationsAssembly("TestCore")));

1、在项目运行时,会首先执行ConfigureServices()方法。

2、连接数据库的字符串connection可配置在appsettings.json文件中,在此暂不做介绍。

3、"TestCore"为配置此上下文维护迁移的程序集

6、使用程序包管理器控制台命令生成数据库

打开程序包管理器控制台选择默认项目后 输入数据迁移命令:Add-Migration elen  (elen随意输入)

PM> Add-Migration elen

迁移成功,生成文件Migrations(可删除)

继续输入创建数据库命令Update-Database向其应用新的迁移

PM> Update-Database

创建数据库成功,此时SqlServer2012中已存在数据库TestDb

1、生成数据库时会生成迁移历史表__EFMigrationsHistory,请勿删除。

2、在需要修改数据库字段时,切记不要直接在数据库修改,可在模型类中修改后运行Update-Database命令进行修改。

至此,使用EF Core+CodeFirst建立ASP.NET Core MVC项目介绍完毕,在学习和使用过程中我遇到了很多坑,本文是我在操作相对熟练以及熟悉其基本原理后所写,适合初学者参考,如有不足之处欢迎大家留言评论!

使用EF Core+CodeFirst建立ASP.NET Core MVC项目的更多相关文章

  1. ASP.NET Core 使用 EF 框架查询数据 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 使用 EF 框架查询数据 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 使用 EF 框架查询数据 上一章节我们学习了如何设置 ...

  2. Orchard Core Framework:ASP.NET Core 模块化,多租户框架

    Orchard Core Framework:ASP.NET Core 模块化,多租户框架 上一篇编写Orchard Core一分钟搭建ASP.NET Core CMS ,介绍ASP.NET Core ...

  3. ASP.NET Core Identity 配置 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core Identity 配置 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core Identity 配置 上一章节我们简单介绍了下 Id ...

  4. ASP.NET Core Identity 框架 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core Identity 框架 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core Identity 框架 前面我们使用了 N 多个章节, ...

  5. ASP.NET Core 数据库上下文 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 数据库上下文 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 数据库上下文 上一章节中我们了解了 Entity Framewo ...

  6. ASP.NET Core 新增用户 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 新增用户 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 新增用户 上一章节我们实现了一个注册表单,但也留了一些东西还没完成, ...

  7. ASP.NET Core 动作结果 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 动作结果 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 动作结果 前面的章节中,我们一直使用简单的 C# 类作为控制器. 虽 ...

  8. ASP.NET Core 属性路由 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 属性路由 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 属性路由 经过前面章节的学习,想必你已经对 ASP.NET Core ...

  9. ASP.NET Core 静态文件 - ASP.NET Core 基础教程 - 简单教程,简单编程

    原文:ASP.NET Core 静态文件 - ASP.NET Core 基础教程 - 简单教程,简单编程 ASP.NET Core 静态文件 前几章节中,我们学习了 ASP.NET Core 的中间件 ...

随机推荐

  1. 使用adb 命令(atrace)抓起systrace的方法。

    adb shell atrace -c -b --async_start -z gfx 1. 执行查看adb shell atrace 功能 atrace --h atrace: invalid op ...

  2. 2019牛客国庆day3-G &CF1238E

    牛客G: 给定大小为N的数组a[],给定M组关系,让你重排a[],使得sum{M队关系的绝对值之差}最小.首先将a排序,然后依次把a填入数组. 假设i在二进制下有x个1,用dp[i]更新dp[i|(1 ...

  3. Python 文件读写操作实例详解

    Python提供了必要的函数和方法进行默认情况下的文件基本操作.你可以用file对象做大部分的文件操作 一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法.1.得到当前 ...

  4. 【java异常】redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool

    产生此错误的原因通常是: 一.Redis没有启动: 我自己遇到一次这样的问题.汗! 二.由于防火墙原因无法连接到Redis; 1.服务器防火墙入站规则. 2.访问Redis的应用程序所在主机的出站规则 ...

  5. CSS布局对齐的小技巧

    类似以上这种对齐怎么做? 很简单,上面是的污水开始的位置是由于被"能源种类"顶着,下面没有字怎么办?最差的办法就是用margin-left,因为在不同的机器上,可能会出现兼容性问题 ...

  6. IE和火狐的事件机制有什么区别

    1.IE的事件流是冒泡流,火狐支持冒泡流和捕获流. 2.阻止事件冒泡:IE---e.cancelBubble = true;    火狐---e.stopPropagation();

  7. 最短路径 | 1003 dfs 或 dij ,单源最短路径条数与经过的点权最大

    这题很早之前就遇到过,是pat留给我的第一印象,然而昨天却有点写不出来.今天dfs用了10分钟不到写出来了.dij用了大约15分钟,捉虫花了一点时间. dfs: 注意剪枝的时候别剪错就行了. #inc ...

  8. E437: terminal capability "cm" required 解决办法

    E437: terminal capability "cm" required 这个错误一般是环境变量TERM没有配置或者配置错误所致. 解决办法: 执行export TERM=x ...

  9. nginx虚拟机配置

    #虚拟主机的配置server {#监听端口listen 80;#服务器域名server_name localhost;#网页的默认编码#charset koi8r;#访问该虚拟主机的日志位置#acce ...

  10. [C#]AdvPropertyGrid的使用示例(第三方控件:DevComponents.DotNetBar2.dll)

    开发环境:Visual Studio 2019 .NET版本:4.5.2 效果如下: 1.初始化界面: 2.属性“人物”-自定义控件显示: 3.属性“地址”-自定义窗体显示: 4.属性“性别”-枚举显 ...