微软跨平台ORM框架之EFCore — 约定与属性映射

EFCore中的约定简单来说就是规则,CodeFirst基于模型的约定来映射表结构。除此之外还有Fluent API、Data Annotations(数据注释) 可以帮助我们进一步配置模型。

按照这三者的优先级高低排序分别是:Fluent API、Data Annotations(数据注释)、约定。

1.约定

public class Person
    {
        public int ID { get; set; }
        public int Age { get; set; }
        public bool Status { get; set; }
        public string Name { get; set; }
        public DateTime CreateTime { get; set; }
    }

1.1 主键约定

我们有这样的一个Person类,在实体中如果有名为ID的字段,或者实体名+ID的字段如:PersonID,那么EFCore生成的表会自动标识为主键。并且如果它的类型是int或Guid则会默认自增长。

映射之后的表结构:

我们可以看到C#中的int、bool、string、datetime,分别映射为 int,bit,navarchar(MAX),datetime2(7)。这是因为EFCore的默认约定是这么规定的。道友们可能会想自定义的映射,比如把string映射会varcher,datetime映射为datetime。嗯。。这就需要借助Fluent API或Data Annotations了。

1.2 外键约定

新建一个订单类,并添加Person类型的字段,以及PersonID(以类名+ID的形式),并在上下文中注册。EFCore在映射表时会根据我们给定Person类型和PersonID来添加外键约束。

  public class Order
    {
        public Guid ID { get; set; }
        public int PersonID { get; set; }
        public Person Person { get; set; }
        public string Address { get; set; }
        public string Phone { get; set; }
    }

修改Progarm.cs代码

class Program
    {
        static void Main(string[] args)
        {

            var context = new CoreDbContext();
            // 删除数据库
            context.Database.EnsureDeleted();
            // 告诉EFCore我们要创建数据库
            context.Database.EnsureCreated();
            // 初始化数据
            var person = new Person()
            {
                Name = "季某人",
                Age = 11,
                Status = true,
                CreateTime = DateTime.Now,
            };
            var person2 = new Person()
            {
                Name = "季某人",
                Age = 11,
                Status = true,
                CreateTime = DateTime.Now,
            };
            var order = new Order()
            {
                PersonID = 1,
                Address = "地球XX",
                Phone = "00000"
            };
            context.Person.Add(person);
            context.Person.Add(person2);
            // 这里因为添加了外键,所以要先保存Person,不然会报外键的错误
            context.SaveChanges();
            context.Order.Add(order);
            context.SaveChanges();

            //Console.WriteLine("Hello World!");
        }
    }

启动项目,然后查看数据库。

可以看到数据完成了初始化,并且添加了外键约束。

2.Data Annotations(数据注释)

数据注释就是在属性上添加一些特性标签,告诉EFCore我们要映射的类型是什么样的,当默认的映射不能满足我们的需求时,就可以使用数据注释了。例如前面的映射,string类型映射为数据库的nvarchar(max),DateTime映射为datetime2(7)。 使用数据注释可以改变为我们想要映射成的类型,例如:string映射成varvhar。

添加一个新类OrderDetail,并添加数据注释。

 public class OrderDetail
    {
        [Key] // 标识主键
        public int ID { get; set; }
        [Column(TypeName = "varchar(50)")] // 列的数据类型
        [Required] // 必填列
        public string Price { get; set; }
        public DateTime? CreateTime { get; set; }
        [Column("OrderCode")] // 列的显示名字
        [StringLength(50)] // 列的长度
        public string Code { get; set; }
        public Guid? OrderID { get; set; }

        public Order Order { get; set; }

    }

启动项目,观察映射成的表结构。与实体中的配置一样。

基本常用的就这些,其他的用到的时候可以去官网文档上找。

3.Fluent API

Fluent API 相较于 数据注释更加灵活。它的配置需要写在自定义的上下文类中的OnModelCreating方法中。

比如改变表名,数据类型之类的

效果和数据注释是一样的,值得注意的是当Fluent API 和数据注释同时配置一个属性时,Fluent API会覆盖掉数据注释。

除了上述之外还可以利用Fluent API 统一表的命名规范:例如 "T_+实体名".

  protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            foreach (var item in modelBuilder.Model.GetEntityTypes())
            {
                modelBuilder.Entity(item.Name).ToTable("T_" + item.ClrType.Name);
            }
        }

遍历要映射的实体然后加上 "T_" 前缀。

具体差异可以观看微软EFCore文档,传送门:https://docs.microsoft.com/zh-cn/ef/core/modeling/relational/data-types

原文地址:https://www.cnblogs.com/jixiaosa/p/10328377.html

时间: 2024-10-13 03:42:58

微软跨平台ORM框架之EFCore — 约定与属性映射的相关文章

微软跨平台ORM框架之EFCore

EFCore是微软推出的跨平台ORM框架,想较于EF6.X版本,更加轻量级.EFCore目前已经更新到2.x. 接下来用CodeFirst的方式来使用EFCore. 1.创建控制台程序 2.引入EFCore的Nuget包和Sqlserver的扩展(因为我这里用的Sqlserver数据库,若是别的数据库如Mysql引入相应的包即可). 3.创建继承成自DbContext上下文,并重载OnConfiguring方法来构建数据库连接字符串 public class CoreDbContext : Db

Hibernate ORM框架——续第二章:Hibernate映射关系:单向关联

一:课堂笔记 **********单表映射*************** 1.只有一个实体类映射一个表 2.有一个实体类+ 一个或者多个值类型,合在一起 映射为一个表 **********多表映射*************** 定义:类有多个映射为多个表 **********数据库层面,如ORM无关************** 2个表之间要建立关系?该如何做?有多少种方法 假定有2个表,分别为A,B 3种关系 a)主键关联:A表的主键对应B表的主键,(一对一的关系) 在数据库种如何建立这种关系?

Mego(2) - NET主流ORM框架分析

接上文我们测试了各个ORM框架的性能,大家可以很直观的看到各个ORM框架与原生的ADO.NET在境删改查的性能差异.这里和大家分享下我对ORM框架的理解及一些使用经验. ORM框架工作原理 典型ORM框架实现 EF功能最强的ORM EF与EFCore缺陷 ORM框架工作原理 所有的ORM框架的工作原理都离不开下面这张图,只是每个框架的实现程度不同但是最终的目的是相同的. 如果是一个ORM框架那么一定会有上图中蓝色部分的这几个元素,无论是增删改查对于ORM一定是以对象为起点,使用对象构造出LINQ

基于.NET的微软ORM框架视频教程(Entity Framework技术)

基于.NET的微软ORM框架视频教程(Entity Framework技术) 第一讲  ORM映射 第二讲 初识EntifyFramework框架 第三讲 LINQ表达式查询 第四讲 LINQ方法查询 第五讲 LINQ TO Entities 第六讲 ObjectQuery查询(上) 第七讲 ObjectQuery查询(下) 第八讲 Entity中的增删改及事务处理 第九讲 Entity中的存储过程使用(完) 源代码及视频

.NET 跨平台界面框架和为什么你首先要考虑再三

???原文地址 现在用 C# 来开发?跨平台应用已经有很成熟的方案,即共用非界面代码,而每个操作系统搭配特定的用户界面代码.这个方案的好处是可以直接使用操作系统原生的控件和第三方控件,还能够和操作系统深度集成. 这里的深度集成主要是指一些 Windows 专有的系统特性: Windows 托盘 Windows 跳转列表 Windows 系统主题 也包括一些移动平台的特性,例如 iOS 的原生滑动. ?由于操作系统上其他程序一般都使用原生控件,于是只有当你的程序采用同样技术时,它才能很好地保持一致

最好的5个Android ORM框架

在开发Android应用时,保存数据有这么几个方式, 一个是本地保存,一个是放在后台(提供API接口),还有一个是放在开放云服务上(如 SyncAdapter 会是一个不错的选择). 对于第一种方式,即本地数据存储,如嵌入式SQLLite,你可以选择直接使用SQL语句.Content Provider 或 ORM(对象关系数据映射). 对于 Android 应用的开发,主要是使用Java语言,所以适用于Java语言的一些ORM,也能移植于 Android 平台上. 下面是5个可用ORM的总体介绍

自己写ORM框架 DBUtils

ORM框架想必大家都比较熟知了,即对象关系映射(英语:Object Relation Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说,它其实是创建了一个可在编程语言里使用的"虚拟对象数据库". 当你开发一个应用程序的时候(不使用O/R MAPPING),你可能会写不少数据访问层的代码,用来从数据库保存,删除,读取对象信息,等等. 现在流行的ORM框架有: JAVA系列:APACHE

.Net开源微型ORM框架测评

什么是ORM? 对象关系映射(英语:Object Relation Mapping,简称ORM,或O/RM,或O/R mapping),是一种程序技术,用于实现面向对象编程语言里不同类型系统的数据之间的转换.从效果上说,它其实是创建了一个可在编程语言里使用的“虚拟对象数据库”. 一般的ORM包括以下四部分: 一个对持久类对象进行CRUD操作的API: 一个语言或API用来规定与类和类属性相关的查询: 一个规定MAPPING METADATA的工具: 一种技术可以让ORM的实现同事务对象一起进行D

高效快捷简便易用的基于JSP的框架 MVC+ORM框架- YangMVC

开发目的 @copyright 杨同峰 保留所有权利 本文可以转载,但请保留版权信息 本人高校教师,带着一门动态网站设计课程,前面讲HTML+CSS+DIV,后面将JSP+JDBC+Struts+Hibernate+Spring.对SSH的难用深有体会.从一个空白项目开始配置完SSH,需要20分钟.别吐槽,这还是熟练的情况下...如果你有模板当然binggo就好了.但... 这不是一个框架应该有的样子.框架应该使用简单.配置简单.代码简洁.总之,我思考了一个晚上后决定自己写一个MVC+ORM(数