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

你可能感兴趣的文章
openCV目标识别 目标跟踪 YOLO5深度学习 Python 计算机视觉 计算机毕业设计 源码下载
查看>>
opencv笔记(1):图像缩放
查看>>
opencv笔记(二十四)——得到轮廓之后找到凸包convex hull
查看>>
OpenCV计算点到直线的距离 数学法
查看>>
Opencv识别图中人脸
查看>>
OpenCV读写avi、mpeg文件
查看>>
opencv里用calcCovarMatrix计算协方差矩阵
查看>>
OpenCV错误:在setSize中断言失败(s&>;=0)-尝试将图像放置在网络摄像头提要上时
查看>>
opencv面向对象设计初探
查看>>
OpenCV(1)读写图像
查看>>
OpenCV:不规则形状区域中每种颜色的像素数?
查看>>
OpenCV:概念、历史、应用场景示例、核心模块、安装配置
查看>>
OpenDaylight融合OpenStack架构分析
查看>>
OpenERP ORM 对象方法列表
查看>>
openEuler Summit 2022 成功举行,开启全场景创新新时代
查看>>
openEuler 正式开放:推动计算多样化时代的到来
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
查看>>
OpenFeign 入门与实战
查看>>
OpenFeign源码学习
查看>>