本篇随笔介绍如何使用.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. LCD编程_LCD控制器

    CLKVAL : VCLK = HCLK / [(CLKVAL+1) x 2]--------> CLKVAL = HCLK/VCLK/2-1 在这个地方HCLK=100M,那么VLCK等于多少 ...

  2. Android: Error inflating class android.support.v4.view.ViewPager 问题的解决方法

    ViewPager是个很好很强大的控件,很多应用用它来实现很酷的效果,但是很多情况下在运行时会遇到Error inflating class android.support.v4.view.ViewP ...

  3. jsp获取map

    1.简单Map User user = new User(); user.setName("zmy"); user.setAge(); user.setBirthday(new D ...

  4. JS中把其他类型转换成字符串的三种方法

    1.toString()方法 toString()方法返回的是相应值的字符串表现 数值.布尔值.对象和字符串值都有toString()方法,但是null和undefined值没有这个方法 例子: va ...

  5. jquery保存cookie,php读取cookie操作

    //保存时间 var Days = 30; var exp = new Date(); exp.setTime(exp.getTime() + Days*24*60*60*1000); //保存内容, ...

  6. zzulioj - 2624: 小H的奇怪加法

    题目链接:http://acm.zzuli.edu.cn/problem.php?id=2624 题目描述 小H非常喜欢研究算法,尤其是各种加法.没错加法包含很多种,例如二进制中的全加,半加等.全加: ...

  7. 第二章python中的一切皆对象

    1.函数和类也是对象,属于python的一等公民 赋值给一个变量 可以添加到集合对象之中 可以作为参数传递给函数 可以当作函数的返回值 def ask(name="ask_wzh" ...

  8. [Gamma]Scrum Meeting#5

    github 本次会议项目由PM召开,时间为5月30日晚上10点30分 时长15分钟 任务表格 人员 昨日工作 下一步工作 木鬼 撰写博客,组织例会 撰写博客,组织例会 swoip 前端显示屏幕,翻译 ...

  9. libevent笔记2:Hello_World

    本篇通过libevent提供的Hello_World demo简单介绍基于libevent的TCP服务器的实现 listener listener是libevent提供的一种监听本地端口的数据结构,在 ...

  10. 为什么需要动态SQL

    为什么需要动态SQL 在使用EF或者写SQL语句时,查询条件往往是这样一种非常常见的逻辑:如果客户填了查询信息,则查询该条件:如果客户没填,则返回所有数据. 我常常看到很多人解决这类问题时使用了错误的 ...