.Net Core 学习: Razor Pages -- EF Core简介

EF Core简介

Entity Framework Core(简称EF Core)是.NET应用程序的轻量级、可扩展、开源和跨平台的数据访问技术,用于简化数据库操作。 ‌

  • 对象关系映射(ORM):通过实体类操作数据库,无需手动编写大部分数据访问代码。
  • 支持多种数据库:包括SQLite、MySQL、PostgreSQL、Oracle和Microsoft SQL Server等

ORM框架核心功能

  • 对象-关系映射:将数据库表映射为 C# 实体类
  • 变更跟踪:自动跟踪实体状态变化
  • LINQ 支持:使用 LINQ 语法生成 SQL 查询
  • 数据库迁移:代码优先方式管理数据库架构
  • 事务管理:自动或手动事务控制

基础概念与术语

DbContext:

  • EF Core 的核心类,负责与数据库的交互
  • 包含 DbSet 属性,表示数据库中的表
  • 管理实体的生命周期和状态

实体 (Entity):

  • 映射到数据库表的 .NET
  • 通常是 POCO (Plain Old CLR Object)

DbSet:

  • 表示数据库中的表,类似于集合
  • 可通过 LINQ 查询数据

迁移 (Migrations):

  • 记录数据库结构变更的代码文件
  • 用于更新数据库架构

EF Core所需要的基础包(示例)

项目文件夹配置包引用 --> 在NeGet包管理器里添加(开发方式也以包的方式,所以开发时会引入各种各样的包)


数据库迁移实现代码

1、创建DBContext类:

2、注册上下文服务

①、编辑 Program.cs

②、编辑 appsettings.json

3、创建实体类

这 Gender 是一个枚举类

4、程序包管理器控制台 命令行

Add-Migration + 迁移名称 ---作用:启动迁移并生成迁移的代码

完成后会自动生成迁移的代码:

Update-database ---作用:把操作更新到数据库

数据库中就会生成对应的表结构:

相关推荐
云边散步4 分钟前
godot2D游戏教程系列二(18)
笔记·学习·游戏
風清掦20 分钟前
【江科大STM32学习笔记-09】USART串口协议 - 9.1 STM32 USART串口外设
笔记·stm32·单片机·嵌入式硬件·学习
奶茶精Gaaa34 分钟前
AI实战(二)生成ui自动化
功能测试·学习·自动化
red_redemption2 小时前
自由学习记录(141)
学习
xian_wwq2 小时前
【学习笔记】看参识模型
笔记·学习
星雨流星天的笔记本2 小时前
1、用于制备钙钛矿量子点的新三颈烧瓶的洗涤与使用方法
学习
FPGA小迷弟2 小时前
高频时钟设计:FPGA 多时钟域同步与时序收敛实战方案
前端·学习·fpga开发·verilog·fpga
sensen_kiss2 小时前
CPT306 Principles of Computer Games Design 电脑游戏设计原理 Pt.3 实时图形
学习·计算机视觉
東雪木3 小时前
编程算法学习——栈与队列算法
学习·算法·排序算法
ADHD多动联盟3 小时前
什么是儿童ADHD的运动干预方案?主要有怎样的应对分心走神的疗法?
学习·学习方法·玩游戏