当前位置: 服务支持 >  技术文档 >  EF Core Fluent配置:实体关系与类型映射手册

EF Core Fluent配置:实体关系与类型映射手册

阅读数 148
点赞 12
copyright 著作权
article_banner

使用 Fluent API 配置/映射属性和类型 使用实体框架 code first 时,默认行为是使用一组 ef 中内嵌的约定将 poco 类映射到表。但是,有时您无法或不想遵守这些约定,需要将实体映射到约定指示外的其他对象。 您主要可使用两种方法来配置 EF 使之在映射数据时

使用 Fluent API 配置/映射属性和类型

使用实体框架 code first 时,默认行为是使用一组 ef 中内嵌的约定将 poco 类映射到表。但是,有时您无法或不想遵守这些约定,需要将实体映射到约定指示外的其他对象。

您主要可使用两种方法来配置 EF 使之在映射数据时绕开约定,这两种方法就是 注释和 EF Fluent API。注释仅涵盖一部分 Fluent API 功能,因此有一些情况是无法使用注释实现的。本文旨在演示如何使用 Fluent API 来配置属性。

除了控制映射之外,Fluent API 和注释还可用于配置约束,如字段长度或必需属性,此时这些配置的约束将影响 Code First 所创建的数据库以及实体框架所执行的验证。

 

内容

  • 简介
  • 属性映射
    • 配置主键
    • 配置组合主键
    • 关闭数值主键的标识
    • 指定属性的最大长度
    • 将属性配置为必需
    • 指定不将 CLR 属性映射到数据库中的列
    • 将 CLR 属性映射到数据库中的特定列
    • 重命名模型中未定义的外键
    • 配置字符串属性是否支持 Unicode 内容
    • 配置数据库列的数据类型
    • 配置复杂类型的属性
    • 将属性配置为用作乐观并发令牌
  • 类型映射
    • 将类指定为复杂类型
    • 指定不将 CLR 实体类型映射到数据库中的表
    • 将 CLR 实体类型映射到数据库中的特定表
    • 映射“每个层次结构一张表 (TPH)”继承
    • 映射“每个类型一张表 (TPT)”继承
    • 映射“每个具体类一张表 (TPC)”继承
    • 将实体类型的 CLR 属性映射到数据库中的多个表(实体拆分)
    • 将多个实体类型映射到数据库中的一个表(表拆分)
  • 示例中使用的模型

 

 

简介

通常通过重写派生 DbContext 上的 OnModelCreating 方法来访问 Code First Fluent API。以下示例旨在显示如何使用 Fluent API 执行各种任务,您可以将代码复制出来并进行自定义,使之适用于您的模型。如果您想查看可按原样使用这些示例的模型,本文末尾提供了该模型。

 

属性映射

Property 方法用于为每个属于实体或复杂类型的属性配置特性。Property 方法用于获取给定属性的配置对象。配置对象上的选项特定于要配置的类型;例如,IsUnicode 只能用于字符串属性。

配置主键

有关主键的实体框架约定如下:

1.       您的类定义名称为“ID”或“Id”的属性

2.       或类名后跟“ID”或“Id”。

要显式将某个属性设置为主键,可使用 HasKey 方法。在以下示例中,使用了 HasKey 方法对 OfficeAssignment 类型配置 InstructorID 主键。

相关文章
QR Code
微信扫一扫,欢迎咨询~

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 155-2731-8020
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

手机不正确

公司不为空