- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
1、简介 。
EFcore,可用使得开发人员不需要再去关注数据库的实现,全都由代码进行生成 。
这样有利于减少工作量、数据库快速迁移... 。
2、上手搭建架构 。
(这个图是做完本章内容的完整图,我们一步步深入即可) 。
在写EF之前,先安装好数据库,我选择在 本地安装Sqlserver 。
。
我们先执行最核心的两步,将EF和数据库跑通 。
1)类&表的定义:基本上会保持class和数据库的table字段保持一致,如上 UserModel ,我定义了Staff、Tenant两个类,会自动生成两个表 。
UserModel需要安装 。
Microsoft.EntityFrameworkCore.SqlServer
Staff 。
using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; namespace UserModel { public class Staff { public int Id { get ; set ; } public string Name { get ; set ; } public string Description { get ; set ; } public string ? PhoneNumber { get ; set ; } public string ? Email { get ; set ; } } }
Tenant 。
namespace UserModel { public class Tenant { public int Id { get ; set ; } public string Name { get ; set ; } public string Description { get ; set ; } } }
2)上下文定义:负责关联实体类、访问数据库配置,提供后续生成数据库支持,如上 MyDBContextLibrary 。
MyDBContextLibrary需要安装 。
Microsoft.EntityFrameworkCore.Tools
MyDBContext 。
using Microsoft.EntityFrameworkCore; namespace UserModel { public class MyDBContext : DbContext { public DbSet<Staff> Staffs { get ; set ; } public DbSet<Tenant> Tenants { get ; set ; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { base .OnConfiguring(optionsBuilder); optionsBuilder.UseSqlServer( " Data Source=.;Initial Catalog=master;Integrated Security=True;TrustServerCertificate=yes " ); } } }
准备完毕!! 。
打开【程序包管理器控制台】 。
项目指定到MyDBContext 。
Add-
Migration Ini #添加一个迁移 Ini是为这个迁移起的备注名
Update
-database #更新到数据库,执行了才会同步迁移到数据库
到此,简单的EF框架已经跑起来了 。
3、扩展 。
EF是一个十分强大的框架,我们逐渐扩展知识点.
1)属性定义 。
有两种方式 。
其一 :Data Annotations(数据注解),利用特性进行定义,如对Staff属性进行定义 。
using System.ComponentModel.DataAnnotations; using System.ComponentModel.DataAnnotations.Schema; // Data Annotations例子 namespace UserModel { [Table( " Staff " )] // 可用加特性指定表名 public class Staff { public int Id { get ; set ; } [Required]//必填 [MaxLength( 10 )]//最大长度为10 public string Name { get ; set ; } [Required] public string Description { get ; set ; } public string ? PhoneNumber { get ; set ; } //可空 public string ? Email { get ; set ; } } }
PS:提醒一点,Id / 类名+Id 在迁移到数据库表的时候,会默认为递增序列 。
其二 :Fluent API,微软官方提供的API,如对Tenant属性进行定义 。
在MyDBContext,重写OnModelCreating方法 。
using Microsoft.EntityFrameworkCore; namespace UserModel { public class MyDBContext : DbContext { public DbSet<Staff> Staffs { get ; set ; } public DbSet<Tenant> Tenants { get ; set ; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { base .OnConfiguring(optionsBuilder); optionsBuilder.UseSqlServer( " Data Source=.;Initial Catalog=master;Integrated Security=True;TrustServerCertificate=yes " ); } protected override void OnModelCreating(ModelBuilder modelBuilder) { base .OnModelCreating(modelBuilder); modelBuilder.Entity<Tenant>().Property(x=>x.Description).IsRequired(false); /*指定Description非必填*/ } } }
当然,我们容易看到,如果实体很多,属性直接写在这里代码太冗长了 。
改变一下方法,添加一个 TenantConfig类 。
using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Metadata.Builders; namespace UserModel { public class TenantConfig : IEntityTypeConfiguration<Tenant> { public void Configure(EntityTypeBuilder<Tenant> builder) { builder.ToTable( " Tenant " ); // 可重新指定表名 builder.HasKey(x => x.Id); builder.Property(x =>x.Name).IsRequired().HasColumnType( " nvarchar(100) " ); builder.Property(x =>x.Description).IsRequired( false ); } } }
然后 DbContext:
using Microsoft.EntityFrameworkCore; namespace UserModel { public class MyDBContext : DbContext { public DbSet<Staff> Staffs { get ; set ; } public DbSet<Tenant> Tenants { get ; set ; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { base .OnConfiguring(optionsBuilder); optionsBuilder.UseSqlServer( " Data Source=.;Initial Catalog=master;Integrated Security=True;TrustServerCertificate=yes " ); } protected override void OnModelCreating(ModelBuilder modelBuilder) { base .OnModelCreating(modelBuilder); modelBuilder.ApplyConfigurationsFromAssembly(typeof(Tenant).Assembly); //利用反射,加载Tenant程序集下的IEntityTypeConfiguration } } }
完成,再次生成一个迁移到数据库看看!!! 。
代码不会一步到位的,大家逐步测试严重,这边我就不贴数据库的截图了 。
4、最后说明一下ConsoleApp 。
Program 。
using UserModel; using ( var ctx = new MyDBContext()) { var s = new Staff() { Name = " kxy2 " , Description = " 三好员工 " , PhoneNumber = " 1234567890 " }; ctx.Staffs.Add(s); var t = new Tenant() { Name = " ccc " , }; ctx.Tenants.Add(t); ctx.SaveChanges(); } Console.ReadLine();
测试数据而已,怎么方便怎么来 。
PS:有个点,如果设置ConsoleApp为启动项,迁移的时候会验证启动项的依赖,从而产生错误 。
ConsoleApp需要安装 。
Microsoft.EntityFrameworkCore.Design
至此,完成!! 。
感谢关注 。
。
最后此篇关于Net6EFcore框架介绍的文章就讲到这里了,如果你想了解更多关于Net6EFcore框架介绍的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!