博客
关于我
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/

你可能感兴趣的文章
OO第四单元总结
查看>>
OO第四次博客作业
查看>>
OO面向对象编程:第三单元总结
查看>>
Opacity多浏览器透明度兼容处理
查看>>
OPC在工控上位机中的应用
查看>>
VSCode在终端中使用yarn命令
查看>>
OPEN CASCADE Curve Continuity
查看>>
Open Graph Protocol(开放内容协议)
查看>>
Open vSwitch实验常用命令
查看>>
Open WebUI 忘了登入密码怎么办?
查看>>
open***负载均衡高可用多种方案实战讲解02(老男孩主讲)
查看>>
Open-E DSS V7 应用系列之五 构建软件NAS
查看>>
Open-Sora代码详细解读(1):解读DiT结构
查看>>
Open-Sora代码详细解读(2):时空3D VAE
查看>>
Open-Source Service Discovery
查看>>
open-vm-tools-dkms : 依赖: open-vm-tools (>= 2:9.4.0-1280544-5ubuntu3) 但是它将不会被安装
查看>>
open3d-Dll缺失,未找到指定模块解决
查看>>
openai Midjourney代理服务 gpt大模型第三方api平台汇总 支持国内外各种大模型 持续更新中...
查看>>
OpenAll:Android打开组件新姿势【仅供用于学习了解ButterKnife框架基本原理】
查看>>
OpenASR 项目使用教程
查看>>