博客
关于我
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实现串口通讯(附完整源码)
查看>>
Objective-C实现串逐位和(附完整源码)
查看>>
Objective-C实现串链式存储简单匹配(附完整源码)
查看>>
Objective-C实现主存储器空间的分配和回收(附完整源码)
查看>>
Objective-C实现乘方运算---m的n次方(附完整源码)
查看>>
Objective-C实现乘法持续性multiplicative persistence算法(附完整源码)
查看>>
Objective-C实现二分查找最接近的数值m(附完整源码)
查看>>
Objective-C实现二叉搜索树算法(附完整源码)
查看>>
Objective-C实现二叉树层序遍历(附完整源码)
查看>>
Objective-C实现二叉树遍历算法(附完整源码)
查看>>
Objective-C实现二次方程复数算法(附完整源码)
查看>>
Objective-C实现二维向量以及各种向量操作算法(附完整源码)
查看>>
Objective-C实现二进制和算法(附完整源码)
查看>>
Objective-C实现二进制移位算法(附完整源码)
查看>>