博客
关于我
EF Core 5.0 DB First和CodeFirst实现
阅读量:456 次
发布时间:2019-03-06

本文共 2768 字,大约阅读时间需要 9 分钟。

EF Core - DB First 和 Code First 开发指南

在 Entity Framework Core 开发中,DB First 和 Code First 是两种常用的数据绑定模式。这种指南将详细介绍这两种模式的安装、配置以及常用操作。


一、DB First

DB First 是基于数据库架构生成 DbContext 及实体类型的过程。这种模式适合从现有数据库迁移为代码,或者作为代码生成的基础。

1. 安装工具

使用 .NET Core CLI 安装必要工具:

dotnet tool install --global dotnet-efdotnet add package Microsoft.EntityFrameworkCore.Design

2. 安装数据库 providers

安装对应数据库的 provider:

dotnet add package Pomelo.EntityFrameworkCore.MySql --version 5.0.0-alpha.2

3. 生成 DbContext 和 实体模型

使用 CLI 生成代码:

dotnet ef dbcontext scaffold "Server=localhost;Uid=root;Pwd=123456;Database=databaseName" Pomelo.EntityFrameworkCore.MySql

二、Code First

Code First 是基于 DbContext 和 实体类型生成数据库架构的过程。这种模式适合从代码开始,逐步创建数据库。

1. 安装工具

同样安装必要工具:

dotnet tool install --global dotnet-efdotnet add package Microsoft.EntityFrameworkCore.Design

2. 安装数据库 providers

安装对应数据库的 provider:

dotnet add package Pomelo.EntityFrameworkCore.MySql --version 5.0.0-alpha.2

3. 创建 DbContext 和 实体模型

定义 DbContext 和 实体类:

using System.Collections.Generic;using Microsoft.EntityFrameworkCore;namespace EFGetStarted{    public class BloggingContext : DbContext    {        public DbSet
Blogs { get; set; } public DbSet
Posts { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder options) => options.UseSqlite("Data Source=blogging.db"); } public class Blog { public int BlogId { get; set; } public string Url { get; set; } public List
Posts { get; set; } = new(); } public class Post { public int PostId { get; set; } public string Title { get; set; } public string Content { get; set; } public int BlogId { get; set; } public Blog Blog { get; set; } }}

4. 创建数据库

生成初始迁移并应用:

dotnet ef migrations add InitialCreatedotnet ef database update

5. 更新数据库

在属性字段变更时,更新数据库结构:

dotnet ef migrations removedotnet ef database update

三、参数说明

NET Core CLI 下 dotnet ef dbcontext 参数说明

以下是 dotnet ef dbcontext 命令的常用参数:

选项 简写 说明
--data-annotations -d 使用属性可在可能的架构中配置模型(默认使用 Fluent API)
--context -c 生成的 DbContext 类名称
--context-dir DbContext 类所在目录
--context-namespace 生成的 DbContext 命名空间
--force -f 覆盖现有文件
--output-dir -o 输出文件的目录
--namespace -n 所有生成类的命名空间
--schema 需要生成的架构
--table -t 需要生成的表
--use-database-names 使用数据库中的表和列名称
--no-onconfiguring 禁止生成 OnConfiguring 方法
--no-pluralize 不使用复数化程序

Scaffold-DbContext 参数说明

用于为 DbContext 生成数据库和实体类型的命令:

参数 说明
-connection 数据库连接字符串
-provider 数据库提供程序名称
-output-dir 输出文件的目录
-context-dir DbContext 类所在目录
-namespace 生成类的命名空间
-context 生成的 DbContext 类名称
-schema 需要生成的架构
-table 需要生成的表
--data-annotations 使用属性配置模型
--use-database-names 使用数据库中的表和列名称
--force 覆盖现有文件
--no-onconfiguring 禁止生成 OnConfiguring 方法
--no-pluralize 不使用复数化程序

通过以上命令,可以轻松地在项目中配置和使用 EF Core 的数据库绑定功能。

转载地址:http://oqlyz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现快速排序算法(附完整源码)
查看>>
Objective-C实现恩尼格玛密码机算法(附完整源码)
查看>>
Objective-C实现感知哈希算法(附完整源码)
查看>>
Objective-C实现感知哈希算法(附完整源码)
查看>>
Objective-C实现截留雨水问题的动态编程方法算法(附完整源码)
查看>>
Objective-C实现截留雨水问题的蛮力方法的算法(附完整源码)
查看>>
Objective-C实现打印10000以内的完数(附完整源码)
查看>>
Objective-C实现打印1000以内的水仙花数(附完整源码)
查看>>
Objective-C实现打印九九乘法表(附完整源码)
查看>>
Objective-C实现打印从 0 到 n 的卡特兰数算法(附完整源码)
查看>>
Objective-C实现打印函数调用堆栈( 附完整源码)
查看>>
Objective-C实现打印月份的日历算法(附完整源码)
查看>>
Objective-C实现打印杨辉三角(附完整源码)
查看>>
Objective-C实现打印某年的历法日期(附完整源码)
查看>>
Objective-C实现打印魔方矩阵(附完整源码)
查看>>
Objective-C实现打格点算法(附完整源码)
查看>>
Objective-C实现批量修改文件类型算法(附完整源码)
查看>>
Objective-C实现找出一个数的质因数primeFactors算法(附完整源码)
查看>>
Objective-C实现找出买卖股票的最大利润算法(附完整源码)
查看>>
Objective-C实现找出二维数组中的鞍点(附完整源码)
查看>>