EFCodeFirst属性映射约定
EFCodeFirst属性映射约定
CodeFirst与数据表之间得映射方式又两种:Data Annotation和Fluent API
默认约定:
表名为类名的复数。
创建表得所有者为dbo。
int类型属性映射成数据库int类型。
string类型属性映射成数据库NVARCHAR类型。
若类的字符串类型属性未设置MaxLength,则生成对应的列类型为NVARCHAR(MAX)。
默认主键约束:属性名为[ID]或[类名 + ID]
对于int类型主键,会自动增长。
1 自定义映射表名以及所有者
Data Annotation
- //必要引用
- using System.ComponentModel.DataAnnotations.Schema;
- //映射表名
- [Table("Product")]
- public class Product
- //映射表名以及所有者
- [Table("Product", Schema = "dbo")]
- public class Product
Fluent API方式
- //重写OnModelCreating方法实现 映射表名
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Entity<Product>().ToTable("Product");
- }
- //重写OnModelCreating方法实现 映射表名以及所有者
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Entity<Product>().ToTable("Product", "dbo");
- }
2.字段名、长度、数据类型及是否可空
Data Annotation
- //映射列名
- [Column("ProductID")]
- public int ProductID { get; set; }
- //映射列名,长度,是否为空
- [MaxLength(100)]
- [Required, Column("ProductName")]
- public string ProductName { get; set; }
- //指定映射的数据类型
- [Column("UnitPrice", TypeName = "MONEY")]
- public decimal UnitPrice { get; set; }
- //设置Text
- [Column("Remark", TypeName = "text")]
- public string Remark { get; set; }
Fluent API方式
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- //映射列名
- modelBuilder.Entity<Product>().Property(t => t.ProductID)
- .HasColumnName("ProductID");
- //映射列名,是否为空,最大长度
- modelBuilder.Entity<Product>().Property(t => t.ProductName)
- .IsRequired()
- .HasColumnName("ProductName")
- .HasMaxLength(100);
- }
- //指定映射的数据类型
- modelBuilder.Entity<Product>().Property(t => t.UnitPrice)
- .HasColumnName("UnitPrice")
- .HasColumnType("MONEY");
- //设置Text
- modelBuilder.Entity<Category>().Property(t => t.Remark)
- .HasColumnName("Remark")
- .HasColumnType("text");
3.主键
Data Annotation
- [Key]
- [Column("ProductID")]
- public int ProductID { get; set; }
Fluent API方式
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Entity<Product>().HasKey(t => t.ProductID);
- }
- //多主键
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Entity<Product>().HasKey(t => new { t.KeyID, t.CandidateID });
- }
4.数据库自动生成字段值
Data Annotation
- //取消int类型主键自动增长
- [Key]
- [Column("ProductID")]
- [DatabaseGenerated(DatabaseGeneratedOption.None)]
- public int ProductID { get; set; }
- [Key]
- [Column("CategoryID")]
- [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
- public int CategoryID { get; set; }
Fluent API方式
- //取消int类型主键自动增长
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Entity<Product>().HasKey(t => t.ProductID);
- modelBuilder.Entity<Product>().Property(t => t.ProductID)
- .HasColumnName("ProductID")
- .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);
- }
- modelBuilder.Entity<Category>().ToTable("Category", "dbo");
- modelBuilder.Entity<Category>().HasKey(t => t.CategoryID);
- modelBuilder.Entity<Category>().Property(t => t.CategoryID)
- .HasColumnName("CategoryID")
- .HasDatabaseGeneratedOption(DatabaseGeneratedOption.Identity);
- }
5.数字类型长度及精度
Fluent API方式
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Entity<Product>().Property(t => t.UnitPrice)
- .HasColumnName("UnitPrice")
- .HasPrecision(18, 2);
- }
6.非数据库字段属性
Data Annotation
- [NotMapped]
- public string Remark { get; set; }
Fluent API方式
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Entity<Product>().Ignore(t => t.Remark);
- }
7.Fluent API配置Configuration映射类
方便维护
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.ComponentModel.DataAnnotations.Schema;
- using System.Data.Entity.ModelConfiguration;
- using Portal.Entities;
- namespace Portal.Mapping
- {
- public class ProductMap : EntityTypeConfiguration<Product>
- {
- public ProductMap()
- {
- // Primary Key
- this.HasKey(t => t.ProductID);
- // Properties
- this.Property(t => t.ProductID)
- .HasDatabaseGeneratedOption(DatabaseGeneratedOption.None);
- this.Property(t => t.ProductName)
- .IsRequired()
- .HasMaxLength(100);
- // Table & Column Mappings
- this.ToTable("Product");
- this.Property(t => t.ProductID).HasColumnName("ProductID");
- this.Property(t => t.ProductName).HasColumnName("ProductName");
- this.Property(t => t.UnitPrice)
- .HasColumnName("UnitPrice")
- .HasPrecision(18, 2);
- }
- }
- }
- protected override void OnModelCreating(DbModelBuilder modelBuilder)
- {
- modelBuilder.Configurations.Add(new ProductMap());
- }
EFCodeFirst属性映射约定的更多相关文章
- EFCodeFirst关系映射约定
EFCodeFirst关系映射约定 EFCodeFirst 关系映射约定 默认多重关系的一些约定规则: 1.一对多关系 两个类中分别包含一个引用和一个集合属性. 两个类中一个类包含另一个类的引用属性. ...
- Entity Framework Code First属性映射约定
Entity Framework Code First与数据表之间的映射方式有两种实现:Data Annotation和Fluent API.本文中采用创建Product类为例来说明tity Fram ...
- 【EF】Entity Framework实现属性映射约定
Entity Framework Code First属性映射约定中“约定”一词,在原文版中为“Convention”,翻译成约定或许有些不好理解,这也是网上比较大多数的翻译,我们就当这是Entity ...
- 补习知识:Entity Framework Code First属性映射约定
Entity Framework Code First与数据表之间的映射方式有两种实现:Data Annotation和Fluent API.本文中采用创建Product类为例来说明tity Fram ...
- Entity Framework Code First属性映射约定 转载https://www.cnblogs.com/libingql/p/3352058.html
Entity Framework Code First属性映射约定 Entity Framework Code First与数据表之间的映射方式有两种实现:Data Annotation和Flue ...
- Entity Framework实现属性映射约定
Entity Framework Code First属性映射约定中“约定”一词,在原文版中为“Convention”,翻译成约定或许有些不好理解,这也是网上比较大多数的翻译,我们就当这是Entity ...
- EntityFramework Core 2.1重新梳理系列属性映射(一)
前言 满血复活啦,大概有三个月的时间没更新博客了,关于EF Core最新进展这三个月也没怎么去看,不知现阶段有何变化没,本文将以EF Core 2.1稳定版本作为重新梳理系列,希望对看本文的你有所帮助 ...
- 10.2.翻译系列:使用Fluent API进行属性映射【EF 6 Code-First】
原文链接:https://www.entityframeworktutorial.net/code-first/configure-property-mappings-using-fluent-api ...
- Hibernate持久化类属性映射
Hibernate充当应用程序和数据库之间的中间件,实现二者之间的交互操作,他对JDBC进行了封装,以完全面向对象的方式来操作数据. 适用于有多个数据源的情况下,不必去考虑不同数据源的操作差异. Hi ...
随机推荐
- 各个复位标志解析,让我们对MCU的程序的健康更有把控
作者:良知犹存 转载授权以及围观:欢迎添加微信公众号:Conscience_Remains 总述 曾经开发的时候遇到这样情况,我们开发的设备需要长时间工作上报信息,但是我们在后台查看上报数据,发现设备 ...
- Hyperbase数据迁移
原老集群有100台服务器,新增90台服务器和原来的服务器构成新Hyperbase集群最初考虑有两种方案distcp和snapshot,由于distcp进行数据迁移时不在HBase本身控制范围内,故选用 ...
- for循环实现的一些小例子
1.1-10阶乘和 package HELLO; public class exercise5 { /** 1-10阶乘和 */ public static void main(String[] ar ...
- 2019牛客暑期多校训练营(第二场)A Eddy Walker(打表求概率)
题意:给你n,m分别表示 长度为n的环 和最后走到的位置m 问从0点出发每次都能能往前或者往后走 求最后在m点的概率思路:我们可以先打表模拟一下 发现好像每个点的概率大概都是1/(n-1) 打表代码: ...
- Codeforces Round #627 (Div. 3) D - Pair of Topics(双指针)
题意: 有长为n的a,b两序列,问满足ai+aj>bi+bj(i<j)的i,j对数. 思路: 移项得:(ai-bi)+(aj-bj)>0,i<j即i!=j,用c序列保存所有ai ...
- Educational Codeforces Round 88 (Rated for Div. 2) D. Yet Another Yet Another Task(枚举/最大连续子序列)
题目链接:https://codeforces.com/contest/1359/problem/D 题意 有一个大小为 $n$ 的数组,可以选取一段连续区间去掉其中的最大值求和,问求和的最大值为多少 ...
- Codeforces Round #660 (Div. 2) A. Captain Flint and Crew Recruitment、Captain Flint and a Long Voyage
题目链接:Captain Flint and Crew Recruitment 题意: t组输入,每一组输入一个n.这里我们说一下题目定义的近似质数概念: "如果可以将正整数x表示为p⋅q, ...
- Codeforces Round #340 (Div. 2) E. XOR and Favorite Number
time limit per test 4 seconds memory limit per test 256 megabytes input standard input output standa ...
- Entity Framework (EF) Core学习笔记 1
1. Entity Framework (EF) Core 是轻量化.可扩展.开源和跨平台的数据访问技术,它还是一 种对象关系映射器 (ORM),它使 .NET 开发人员能够使用面向对象的思想处理数据 ...
- PowerShell随笔8 --- function
为了脚本逻辑的重复使用,我们更多时候会封装成方法.PowerShell的function和C#.JavaScript的定义有些区别. 我们直接看例子: 可以看到,定义方法并不是这样的: functio ...