.Net Core 使用EF Core codefirst模式
.Net Core 使用EF Core codefirst模式
什么是codefirst模式#
EF Core有两种数据库设计模式,DBfirst 数据库优先、Codefirst 代码优先。
1、我们一般设计是先添加数据库表信息,然后将数据库的信息更新到项目实体中。这种做法就是我们的DBfirst模式。
2、使用codefirst模式,我们就可以先创建表实体,添加字段限制,完事之后执行3中的两条命令就好了,真的很香呀。
3、代码迁移:Add-Migration "更新内容"、数据库更新:update-database。
codefirst模式的使用#
首先你要创建一个项目,我使用的.net 5 创建了一个类库,然后我们先引用基本EF Core的基本类库、再然后创建一个数据库上下文,添加实体,执行语句就下班啦。
首先我是连接mysql数据库,其他数据库一样的操作,只是引用的包不一样。
1、Microsoft.EntityFrameworkCore
2、Microsoft.EntityFrameworkCore.Design
3、Microsoft.EntityFrameworkCore.Tools
4、Pomelo.EntityFrameworkCore.MySql
/// <summary>
/// 数据库连接对象
/// </summary>
public class ShopMorningContext : DbContext
{
public ShopMorningContext()
{
}
public ShopMorningContext(DbContextOptions option) : base(option)
{
}
public DbSet<Sys_User> Sys_Users { set; get; }
public DbSet<User_Address> User_Addresss { set; get; }
/// <summary>
/// 重写父类的方法 用于连接数据库
/// </summary>
/// <param name="optionsBuilder"></param>
protected override void OnConfiguring(DbContextOptionsBuilder
optionsBuilder)
{
if (!optionsBuilder.IsConfigured)
{
optionsBuilder.UseMySql(
"Server=xxx;Port=xxx;Database=xxx;Uid=xxx;Pwd=xxx;",
new MySqlServerVersion(new Version(8, 0,
21)),
mySqlOptions => mySqlOptions
.CharSetBehavior(CharSetBehavior.NeverAppend))
.EnableSensitiveDataLogging()
.EnableDetailedErrors();
}
}
}
当我们添加好了数据库上下文对象之后,也添加数据库实体就可以执行命令啦(下图是执行命令的地方,怕你第一次听说这个东西。)
代码迁移:Add-Migration "更新内容"、数据库更新:update-database。
执行完之后项目会多一个Migrations文件夹,这个是项目的迁移记录。
作者:匿名
出处:https://www.cnblogs.com/chenxi001/p/14377672.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架