.net core 1.1下的EntityFramework Code First

简介:

新建asp.net core项目,然后把.net core引用的类库升级到1.1,这时,需要手动在project.json下添加一个runtimes节点,如下:

"runtimes": {

  "win10-x64": {}

}

 同时在Nuget中添加下面三个类库(1.1版本):

Microsoft.EntityFrameworkCore.Design

Microsoft.EntityFrameworkCore.SqlServer

Microsoft.EntityFrameworkCore.Tools

 

接下来定义DbContext,用来生成数据库,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using  Microsoft.EntityFrameworkCore;
using  System.Collections.Generic;
using  System.ComponentModel.DataAnnotations;
  
namespace  EntityFrameworkDemo.Model
{
     /// <summary>
     /// 数据库对象
     /// </summary>
     public  class  PermissionContext : DbContext
     {
         public  PermissionContext(DbContextOptions<PermissionContext> opt) :  base (opt)
         {
         }
         protected  override  void  OnModelCreating(ModelBuilder modelBuilder)
         {
             //确定UserRole表中的两个字段是联合主键
             modelBuilder.Entity<UserRole>()
                 .HasKey(u=> new  { u.UserID,u.RoleID});
         }
         public  DbSet<User> Users
         get set ; }
         public  DbSet<Role> Roles
         get set ; }
  
         public  DbSet<UserRole> UserRoles
         get set ; }
     }
     /// <summary>
     /// 用户表
     /// </summary>
     public  class  User
     {
         [Key]
         public  int  ID
         get set ; }
         public  string  UserName
         get set ; }
  
         public  string  Password
         get set ; }
  
         public  List<UserRole> UserRoles {  get set ; }
     }
     /// <summary>
     /// 角色表
     /// </summary>
     public  class  Role
     {
         [Key]
         public  int  ID
         get set ; }
         public  string  RoleName
         {
             get ; set ;
         }
         public  List<UserRole> UserRoles {  get set ; }
     }
     /// <summary>
     /// 用户角色关系
     /// </summary>
     public  class  UserRole
     {
       
         public  int  UserID
         get set ; }
       
         public  int  RoleID
         get set ; }
  
         public  User User{  get set ; }
         public  Role Role {  get set ; }
     }
}


这时,需要在StartUp.cs中添加数据连字符串,来指导自动生成数据库时的服务器,数据库名等信息

1
2
3
4
5
6
7
public  void  ConfigureServices(IServiceCollection services)
{
     var  connection =  @"Server=.;Database=PermissionDb;Trusted_Connection=True;" ;
     services.AddDbContext<PermissionContext>(options => options.UseSqlServer(connection));
  
     services.AddMvc();
}


现在,先Build一下项目,用两个命令在程序包管理器控制台(vs的菜单“工具”-“NuGet包管理器”-“程序包管理器控制台”)中执行:

Add-Migration MyFirstMigration

用来生成命令,生成数据库和表的C#代码

Update-Database

执行生成的代码

在用Add-Migration MyFirstMigration时会报个错,在netcoreapp1.1中没有需要的项目配置文件(.json的),这时打开bin目录,会发现在netcoreapp1.1下会多一个win10-x64文件夹,这正是我们手工在project.json中添加的,打开这个文件夹,把里面对应的.json复制出来就可以(这里应该是Add-MigrationMyFirstMigration生成代码时,默认的寻找配置文件与我们手工添加runtimes的路径不一直导致)

 wKiom1iKmvaTsjQTAADatm1hv7I382.png-wh_50

复制完后再Add-Migration MyFirstMigration一次

会发现在项目中添加了一个文件夹Migrations,并在下面生成两个文件,这便是生成数据库所需的指令。

现在再执行Update-Database

wKioL1iKmwvAPyhgAACmtzGMgtU688.png-wh_50

当执行成功后,用SQL Server的管理工具查看,生成的数据库,并且表中的表关系入下:

wKioL1iKmxeQbjzBAABS1UJXUBo102.png-wh_50




















本文转自桂素伟51CTO博客,原文链接: http://blog.51cto.com/axzxs/1894317,如需转载请自行联系原作者








相关文章
|
2月前
|
存储 开发框架 JSON
ASP.NET Core OData 9 正式发布
【10月更文挑战第8天】Microsoft 在 2024 年 8 月 30 日宣布推出 ASP.NET Core OData 9,此版本与 .NET 8 的 OData 库保持一致,改进了数据编码以符合 OData 规范,并放弃了对旧版 .NET Framework 的支持,仅支持 .NET 8 及更高版本。新版本引入了更快的 JSON 编写器 `System.Text.UTF8JsonWriter`,优化了内存使用和序列化速度。
|
19天前
|
开发框架 .NET C#
在 ASP.NET Core 中创建 gRPC 客户端和服务器
本文介绍了如何使用 gRPC 框架搭建一个简单的“Hello World”示例。首先创建了一个名为 GrpcDemo 的解决方案,其中包含一个 gRPC 服务端项目 GrpcServer 和一个客户端项目 GrpcClient。服务端通过定义 `greeter.proto` 文件中的服务和消息类型,实现了一个简单的问候服务 `GreeterService`。客户端则通过 gRPC 客户端库连接到服务端并调用其 `SayHello` 方法,展示了 gRPC 在 C# 中的基本使用方法。
30 5
在 ASP.NET Core 中创建 gRPC 客户端和服务器
|
1天前
|
开发框架 .NET 开发者
简化 ASP.NET Core 依赖注入(DI)注册-Scrutor
Scrutor 是一个简化 ASP.NET Core 应用程序中依赖注入(DI)注册过程的开源库,支持自动扫描和注册服务。通过简单的配置,开发者可以轻松地从指定程序集中筛选、注册服务,并设置其生命周期,同时支持服务装饰等高级功能。适用于大型项目,提高代码的可维护性和简洁性。仓库地址:&lt;https://github.com/khellang/Scrutor&gt;
14 5
|
9天前
|
开发框架 缓存 .NET
GraphQL 与 ASP.NET Core 集成:从入门到精通
本文详细介绍了如何在ASP.NET Core中集成GraphQL,包括安装必要的NuGet包、创建GraphQL Schema、配置GraphQL服务等步骤。同时,文章还探讨了常见问题及其解决方法,如处理复杂查询、错误处理、性能优化和实现认证授权等,旨在帮助开发者构建灵活且高效的API。
18 3
|
3月前
|
开发框架 监控 前端开发
在 ASP.NET Core Web API 中使用操作筛选器统一处理通用操作
【9月更文挑战第27天】操作筛选器是ASP.NET Core MVC和Web API中的一种过滤器,可在操作方法执行前后运行代码,适用于日志记录、性能监控和验证等场景。通过实现`IActionFilter`接口的`OnActionExecuting`和`OnActionExecuted`方法,可以统一处理日志、验证及异常。创建并注册自定义筛选器类,能提升代码的可维护性和复用性。
|
3月前
|
开发框架 .NET 中间件
ASP.NET Core Web 开发浅谈
本文介绍ASP.NET Core,一个轻量级、开源的跨平台框架,专为构建高性能Web应用设计。通过简单步骤,你将学会创建首个Web应用。文章还深入探讨了路由配置、依赖注入及安全性配置等常见问题,并提供了实用示例代码以助于理解与避免错误,帮助开发者更好地掌握ASP.NET Core的核心概念。
109 3
|
2月前
|
开发框架 JavaScript 前端开发
一个适用于 ASP.NET Core 的轻量级插件框架
一个适用于 ASP.NET Core 的轻量级插件框架
|
开发框架 前端开发 .NET
ASP.NET Core 核心特性学习笔记「下」
ASP.NET Core 核心特性学习笔记「下」
|
开发框架 前端开发 中间件
ASP.NET Core 核心特性学习笔记「上」
ASP.NET Core 核心特性学习笔记「上」
|
SQL 机器学习/深度学习 Cloud Native
.NET 云原生架构师训练营(模块二 基础巩固 EF Core 更新和迁移)--学习笔记
- 状态 - 自动变更检测 - 不查询删除和更新 - 并发
253 0
.NET 云原生架构师训练营(模块二 基础巩固 EF Core 更新和迁移)--学习笔记