EFCodeFirst属性映射约定

EFCodeFirst
属性映射约定

CodeFirst与数据表之间得映射方式又两种:Data Annotation和Fluent API

默认约定:

表名为类名的复数。

创建表得所有者为dbo。

int类型属性映射成数据库int类型。

string类型属性映射成数据库NVARCHAR类型。

若类的字符串类型属性未设置MaxLength,则生成对应的列类型为NVARCHAR(MAX)。

默认主键约束:属性名为[ID]或[类名 + ID]

对于int类型主键,会自动增长。

1 自定义映射表名以及所有者

Data Annotation

  1. //必要引用 

  2. using System.ComponentModel.DataAnnotations.Schema; 

  3. //映射表名 

  4. [Table("Product")] 

  5. public class Product 

  6. //映射表名以及所有者 

  7. [Table("Product", Schema = "dbo")] 

  8. public class Product 

Fluent API方式

  1. //重写OnModelCreating方法实现 映射表名 

  2. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  3. modelBuilder.Entity<Product>().ToTable("Product"); 



  4. //重写OnModelCreating方法实现 映射表名以及所有者 

  5. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  6. modelBuilder.Entity<Product>().ToTable("Product", "dbo"); 



2.字段名、长度、数据类型及是否可空

Data Annotation

  1. //映射列名 

  2. [Column("ProductID")] 

  3. public int ProductID { get; set; } 

  4. //映射列名,长度,是否为空 

  5. [MaxLength(100)] 

  6. [Required, Column("ProductName")] 

  7. public string ProductName { get; set; } 

  8. //指定映射的数据类型 

  9. [Column("UnitPrice", TypeName = "MONEY")] 

  10. public decimal UnitPrice { get; set; } 

  11. //设置Text 

  12. [Column("Remark", TypeName = "text")] 

  13. public string Remark { get; set; } 

Fluent API方式

  1. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  2. //映射列名 

  3. modelBuilder.Entity<Product>().Property(t => t.ProductID) 

  4. .HasColumnName("ProductID"); 

  5. //映射列名,是否为空,最大长度 

  6. modelBuilder.Entity<Product>().Property(t => t.ProductName) 

  7. .IsRequired() 

  8. .HasColumnName("ProductName") 

  9.      .HasMaxLength(100); 



  10. //指定映射的数据类型 

  11. modelBuilder.Entity<Product>().Property(t => t.UnitPrice) 

  12. .HasColumnName("UnitPrice") 

  13. .HasColumnType("MONEY"); 

  14. //设置Text 

  15. modelBuilder.Entity<Category>().Property(t => t.Remark) 

  16. .HasColumnName("Remark") 

  17. .HasColumnType("text"); 

3.主键

Data Annotation

  1. [Key] 

  2. [Column("ProductID")] 

  3. public int ProductID { get; set; } 

Fluent API方式

  1. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  2. modelBuilder.Entity<Product>().HasKey(t => t.ProductID); 



  3. //多主键 

  4. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  5. modelBuilder.Entity<Product>().HasKey(t => new { t.KeyID, t.CandidateID }); 



4.数据库自动生成字段值

Data Annotation

  1. //取消int类型主键自动增长 

  2. [Key] 

  3. [Column("ProductID")] 

  4. [DatabaseGenerated(DatabaseGeneratedOption.None)] 

  5. public int ProductID { get; set; } 

  6. [Key] 

  7. [Column("CategoryID")] 

  8. [DatabaseGenerated(DatabaseGeneratedOption.Identity)] 

  9. public int CategoryID { get; set; } 

Fluent API方式

  1. //取消int类型主键自动增长 

  2. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  3. modelBuilder.Entity<Product>().HasKey(t => t.ProductID); 

  4. modelBuilder.Entity<Product>().Property(t => t.ProductID) 

  5. .HasColumnName("ProductID") 

  6. .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None); 



  7. modelBuilder.Entity<Category>().ToTable("Category", "dbo"); 

  8. modelBuilder.Entity<Category>().HasKey(t => t.CategoryID); 

  9. modelBuilder.Entity<Category>().Property(t => t.CategoryID) 

  10. .HasColumnName("CategoryID") 

  11. .HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity); 



5.数字类型长度及精度

Fluent API方式

  1. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  2. modelBuilder.Entity<Product>().Property(t => t.UnitPrice) 

  3. .HasColumnName("UnitPrice") 

  4. .HasPrecision(18, 2); 



6.非数据库字段属性

Data Annotation

  1. [NotMapped] 

  2. public string Remark { get; set; } 

Fluent API方式

  1. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  2. modelBuilder.Entity<Product>().Ignore(t => t.Remark); 



7.Fluent API配置Configuration映射类

方便维护

  1. using System; 

  2. using System.Collections.Generic; 

  3. using System.Linq; 

  4. using System.Text; 


  5. using System.ComponentModel.DataAnnotations.Schema; 

  6. using System.Data.Entity.ModelConfiguration; 


  7. using Portal.Entities; 


  8. namespace Portal.Mapping 



  9. public class ProductMap : EntityTypeConfiguration<Product> 



  10. public ProductMap() 



  11. // Primary Key 

  12. this.HasKey(t => t.ProductID); 


  13. // Properties 

  14. this.Property(t => t.ProductID) 

  15. .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None); 

  16. this.Property(t => t.ProductName) 

  17. .IsRequired() 

  18. .HasMaxLength(100); 


  19. // Table & Column Mappings 

  20. this.ToTable("Product"); 

  21. this.Property(t => t.ProductID).HasColumnName("ProductID"); 

  22. this.Property(t => t.ProductName).HasColumnName("ProductName"); 

  23. this.Property(t => t.UnitPrice) 

  24. .HasColumnName("UnitPrice") 

  25. .HasPrecision(18, 2); 







  1. protected override void OnModelCreating(DbModelBuilder modelBuilder) 



  2. modelBuilder.Configurations.Add(new ProductMap()); 



EFCodeFirst属性映射约定的更多相关文章

  1. EFCodeFirst关系映射约定

    EFCodeFirst关系映射约定 EFCodeFirst 关系映射约定 默认多重关系的一些约定规则: 1.一对多关系 两个类中分别包含一个引用和一个集合属性. 两个类中一个类包含另一个类的引用属性. ...

  2. Entity Framework Code First属性映射约定

    Entity Framework Code First与数据表之间的映射方式有两种实现:Data Annotation和Fluent API.本文中采用创建Product类为例来说明tity Fram ...

  3. 【EF】Entity Framework实现属性映射约定

    Entity Framework Code First属性映射约定中“约定”一词,在原文版中为“Convention”,翻译成约定或许有些不好理解,这也是网上比较大多数的翻译,我们就当这是Entity ...

  4. 补习知识:Entity Framework Code First属性映射约定

    Entity Framework Code First与数据表之间的映射方式有两种实现:Data Annotation和Fluent API.本文中采用创建Product类为例来说明tity Fram ...

  5. Entity Framework Code First属性映射约定 转载https://www.cnblogs.com/libingql/p/3352058.html

    Entity Framework Code First属性映射约定   Entity Framework Code First与数据表之间的映射方式有两种实现:Data Annotation和Flue ...

  6. Entity Framework实现属性映射约定

    Entity Framework Code First属性映射约定中“约定”一词,在原文版中为“Convention”,翻译成约定或许有些不好理解,这也是网上比较大多数的翻译,我们就当这是Entity ...

  7. EntityFramework Core 2.1重新梳理系列属性映射(一)

    前言 满血复活啦,大概有三个月的时间没更新博客了,关于EF Core最新进展这三个月也没怎么去看,不知现阶段有何变化没,本文将以EF Core 2.1稳定版本作为重新梳理系列,希望对看本文的你有所帮助 ...

  8. 10.2.翻译系列:使用Fluent API进行属性映射【EF 6 Code-First】

    原文链接:https://www.entityframeworktutorial.net/code-first/configure-property-mappings-using-fluent-api ...

  9. Hibernate持久化类属性映射

    Hibernate充当应用程序和数据库之间的中间件,实现二者之间的交互操作,他对JDBC进行了封装,以完全面向对象的方式来操作数据. 适用于有多个数据源的情况下,不必去考虑不同数据源的操作差异. Hi ...

随机推荐

  1. 【STM32】PWM波中的时间问题

    我们使用的TIM3定时器是挂载在APB1总线上的,APB1总线的时钟频率为72MHz. APB1总线的时钟频率通过PSC寄存器预分频,得到的频率为(72/(71+1))=1MHz. 定时器的自动重装载 ...

  2. linux(4)Linux 文件内容查看

    查看文件内容总览 cat 由第一行开始显示文件内容 tac 从最后一行开始显示,可以看出 tac 是 cat 的倒着写! nl 显示的时候,顺道输出行号! more 一页一页的显示文件内容 less ...

  3. PTA 乙 1001

    1001 害死人不偿命的(3n+1)猜想 题目描述 卡拉兹(Callatz)猜想: 对任何一个正整数 n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把 (3n+1) 砍掉一半.这样一直反复砍下 ...

  4. Java程序操作HDFS

    1.新建项目2.导包 解压hadoop-2.7.3.tar.gzE:\工具\大数据\大数据提升资料\01-软件资料\06-Hadoop\安装包\Java1.8环境下编译\hadoop-2.7.3\ha ...

  5. Codeforces Global Round 11【ABCD】

    比赛链接:https://codeforces.com/contest/1427 A. Avoiding Zero 题意 将 \(n\) 个数重新排列使得不存在为 \(0\) 的前缀和. 题解 计算正 ...

  6. Codeforces Round #671 (Div. 2)

    比赛链接:https://codeforces.com/contest/1419 A. Digit Game 题意 给出一个 $n$ 位数,游戏规则如下: 1-indexed Raze标记奇数位 Br ...

  7. Codeforces Round #697 (Div. 3) D. Cleaning the Phone (思维,前缀和)

    题意:你的手机有\(n\)个app,每个app的大小为\(a_i\),现在你的手机空间快满了,你需要删掉总共至少\(m\)体积的app,每个app在你心中的珍惜值是\(b_i\),\(b_i\)的取值 ...

  8. ZOJ3640-Help Me Escape 概率dp

    题意: 在一个迷宫中有n条路经,你会被随机传送到一条路径,每条路径有一个挑战难度ci,你最初有一个战斗力f,如果你的战斗力大于ci,那么呆在那里ti天就可以成功逃出迷宫.如果你的战斗力小于等于ci,那 ...

  9. 关于string类中find函数的讲解

    以下所讲的所有的string查找函数,都有唯一的返回类型,那就是size_type,即一个无符号整数(按打印出来的算).若查找成功,返回按查找规则找到的第一个字符或子串的位置:若查找失败,返回npos ...

  10. css sticky & 吸顶效果

    css sticky & 吸顶效果 demo https://codepen.io/xgqfrms/pen/PoqyVYz css position sticky not working ht ...