第十六节: EF的CodeFirst模式通过Fluent API修改默认协定
一. 简介
1. 优先级:Fluent API > data annotations > default conventions.
2. 所有的Fluent API配置都要在 OnModelCreating这个重写方法中进行
3. 常见的配置:
① 获取表对应的配置根: var stu =modelBuilder.Entity<XXX>();
② 设置主键:HasKey<string>(s => s.studentKey);
③ 获取属性:stu.Property(p => p.stuName)
④ 设置可空或非空:IsRequired和IsOptional
⑤ 设置最大值:HasMaxLength
⑥ 修改属性名→修改属性的次序→修改属性对应的数据库类型:HasColumnName→HasColumnOrder→HasColumnType
⑦ 修改表名:ToTable
4. 可以建立多个Fluent API的配置文件,然后通过 modelBuilder.Configurations.Add(new XXX());添加到一起
PS:或者利用这句话 modelBuilder.Configurations.AddFromAssembly(Assembly.GetExecutingAssembly()); 把所有的配置文件一次性全部加进来
二. 代码实战
public class Student5
{
//主键声明
public string studentKey { get; set; } //非空声明
public string stuName { get; set; } //最大长度
public string stuTxt1 { get; set; } //最大长度和最小长度
public string stuTxt2 { get; set; } //设置为时间戳
public byte[] rowVersion { get; set; } //并发检查
public string stuTxt3 { get; set; } //public virtual StudentAddress5 stuAddress5 { get; set; }
}
public class StudentAddress5
{
//既是主键、又是外键
public string stuAddressId { get; set; } //设置映射数据库中表的列名
public string stuAddressName { get; set; } //设置映射数据库中表的列名、顺序、类型
public string stuAddrssName2 { get; set; } //不映射数据
public string addressNum { get; set; } //不映射数据
public string txt1 { get { return stuAddrssName2; } } //不映射数据
public string _txt2 = "";
public string txt2 { set { _txt2 = value; } } //public virtual Student5 stu { get; set; }
} /// <summary>
/// Game实体,与其它两个没有什么直接关系,单纯的为了演示, Fluent API的配置,可以根据实体进行拆分
/// 文件来配置,方便管理
/// </summary>
public class Game
{
public int GameId { get; set; } public string GameName { get; set; }
}
/// <summary>
/// Game实体的配置文件
/// </summary>
public class GameConfiguration : EntityTypeConfiguration<Game>
{
public GameConfiguration()
{
this.HasKey(p => p.GameId); this.Property(p => p.GameName).HasMaxLength().IsRequired();
}
}
public class dbContext5 : DbContext
{
public dbContext5()
: base("name=dbContext5")
{ } public DbSet<Student5> Student5 { get; set; } public DbSet<StudentAddress5> StudentAddress5 { get; set; } protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
//所有的FluentAPI均在方法中进行重写 //一. 属性层次上的设置
var stu = modelBuilder.Entity<Student5>();
var stuAddress = modelBuilder.Entity<StudentAddress5>(); //1. 设置主键
stu.HasKey<string>(s => s.studentKey);
stuAddress.HasKey<string>(s => s.stuAddressId); //为什么需要动态设置主键,有待研究?? //2. 设置非空 (扩展:IsOptional 设置可空)
stu.Property(p => p.stuName).IsRequired(); //3. 设置最大值(不能设置最小值)
stu.Property(p => p.stuTxt1).HasMaxLength(); //4. 修改列的名称、排序、类型
stuAddress.Property(p => p.stuAddrssName2).HasColumnName("myAddress2").HasColumnOrder().HasColumnType("varchar"); //5.修改表名
stu.Map<Student5>(c =>
{
c.ToTable("MyStudent"); }); //6.将一个实体映射成多张表,并分别给其命名
//stuAddress.Map<StudentAddress5>(c =>
//{
// c.Properties(p => new
// {
// p.stuAddressId,
// p.stuAddressName
// });
// c.ToTable("MyStuAddress1");
//}).Map<StudentAddress5>(c =>
//{
// c.Properties(p => new
// {
// p.stuAddressId,
// p.stuAddrssName2
// });
// c.ToTable("MyStuAddress2");
//}); //三. 将Game实体的配置添加进来
modelBuilder.Configurations.Add(new GameConfiguration()); base.OnModelCreating(modelBuilder);
}
}
<!--正宗的CodeFirst Fluent API-->
<add name="dbContext5" connectionString="data source=localhost;initial catalog=CodeFirstDB5;persist security info=True;user id=sa;password=123456;MultipleActiveResultSets=True;App=EntityFramework" providerName="System.Data.SqlClient" />
三. 总结
无论是DataAnnotation还是Fluent API,都会发现一个现象,当数据库结构发生变化的时候,就会抛出异常,不得不把数据库删除,重新生成,这样就会导致原数据库中的数据丢失,在实际开发中,显然是不可取的。那么为什么会抛异常呢?怎么解决这个数据丢失的问题呢?详见下一个章节:数据库初始化策略和数据迁移。
!
- 作 者 : Yaopengfei(姚鹏飞)
- 博客地址 : http://www.cnblogs.com/yaopengfei/
- 声 明1 : 本人才疏学浅,用郭德纲的话说“我是一个小学生”,如有错误,欢迎讨论,请勿谩骂^_^。
- 声 明2 : 原创博客请在转载时保留原文链接或在文章开头加上本人博客地址,否则保留追究法律责任的权利。
第十六节: EF的CodeFirst模式通过Fluent API修改默认协定的更多相关文章
- 第十五节: EF的CodeFirst模式通过DataAnnotations修改默认协定
一. 简介 1. DataAnnotations说明:EF提供以特性的方式添加到 domain classes上,其中包括两类: A:System.ComponentModel.DataAnnota ...
- 第十七节: EF的CodeFirst模式的四种初始化策略和通过Migration进行数据的迁移
一. 四种初始化策略 EF的CodeFirst模式下数据库的初始化有四种策略: 1. CreateDatabaseIfNotExists:EF的默认策略,数据库不存在,生成数据库:一旦model发生变 ...
- ASP.NET MVC深入浅出系列(持续更新) ORM系列之Entity FrameWork详解(持续更新) 第十六节:语法总结(3)(C#6.0和C#7.0新语法) 第三节:深度剖析各类数据结构(Array、List、Queue、Stack)及线程安全问题和yeild关键字 各种通讯连接方式 设计模式篇 第十二节: 总结Quartz.Net几种部署模式(IIS、Exe、服务部署【借
ASP.NET MVC深入浅出系列(持续更新) 一. ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态模 ...
- ASP.NET MVC深入浅出(被替换) 第一节: 结合EF的本地缓存属性来介绍【EF增删改操作】的几种形式 第三节: EF调用普通SQL语句的两类封装(ExecuteSqlCommand和SqlQuery ) 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法 第六节: EF高级属性(二) 之延迟加载、立即加载、显示加载(含导航属性) 第十节: EF的三种追踪
ASP.NET MVC深入浅出(被替换) 一. 谈情怀-ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态 ...
- 第一百二十六节,JavaScript,XPath操作xml节点
第一百二十六节,JavaScript,XPath操作xml节点 学习要点: 1.IE中的XPath 2.W3C中的XPath 3.XPath跨浏览器兼容 XPath是一种节点查找手段,对比之前使用标准 ...
- 第十六节、基于ORB的特征检测和特征匹配
之前我们已经介绍了SIFT算法,以及SURF算法,但是由于计算速度较慢的原因.人们提出了使用ORB来替代SIFT和SURF.与前两者相比,ORB有更快的速度.ORB在2011年才首次发布.在前面小节中 ...
- centos linux系统日常管理3 服务管理ntsysv,chkconfig,系统日志rsyslog,last ,lastb ,exec,xargs,dmesg,screen,nohup,curl,ping ,telnet,traceroute ,dig ,nc,nmap,host,nethogs 第十六节课
centos linux系统日常管理3 服务管理ntsysv,chkconfig,系统日志rsyslog,last ,lastb ,exec,xargs,dmesg,screen,nohup,cur ...
- 第四百一十六节,Tensorflow简介与安装
第四百一十六节,Tensorflow简介与安装 TensorFlow是什么 Tensorflow是一个Google开发的第二代机器学习系统,克服了第一代系统DistBelief仅能开发神经网络算法.难 ...
- EF的CodeFirst模式自动迁移(适用于开发环境)
EF的CodeFirst模式自动迁移(适用于开发环境) 1.开启EF数据迁移功能 NuGet包管理器------>程序包管理控制台---------->Enable-Migrations ...
随机推荐
- 歌曲的BPM (Beat Per Minute)--每分钟节拍数
因为老爸喜欢跳舞,总让我帮他整理舞曲,一会儿要慢三,一会儿要慢四,一会儿又要快四....我真的分不清啊 我想啊,慢三,慢四这些应该是歌曲的节拍吧(后来得知专业术语叫BPM),于是就在网上搜看看能不能通 ...
- thinkphp v5.1 开发笔记
一.安装TP5.1 1.使用git安装 <1>下载Tp git clone https://github.com/top-think/think tp5 <2>安装核心库 gi ...
- 用微软官方的 HTML Help Workshop制作的CHM文件不显示图片解决办法
制作CHM文档,方便小巧还易于查看,用处自不必多说了,最近想把这个季度所学习的内容全部制作成CHM格式文档,给自己后续用来温故而知新,同时也可以做为后起之秀避坑法宝.但是在生成CHM文档之后发现有些地 ...
- Spark的性能调优杂谈
下面这些关于Spark的性能调优项,有的是来自官方的,有的是来自别的的工程师,有的则是我自己总结的. 基本概念和原则 <1> 每一台host上面可以并行N个worker,每一个worke ...
- SpringBoot学习笔记(2) Spring Boot的一些配置
外部配置 Spring Boot允许使用properties文件.yaml文件或者命令行参数作为外部配置 使用@Value注解,可以直接将属性值注入到你的beans中,并通过Spring的Enviro ...
- (九)Delete an Index
Now let’s delete the index that we just created and then list all the indexes again: 现在让我们删除刚刚创建的索引, ...
- MicroPython实例之TPYBoard开发板控制OLED显示中文
0x00 前言 之前看到一篇文章是关于TPYBoard v102控制OLED屏显示的,看到之后就想尝试一下使用OLED屏来显示中文.最近利用空余时间搞定了这个实验,特此将实验过程及源码分享出来,方便以 ...
- 在 .NET Core 中结合 HttpClientFactory 使用 Polly(中篇)
译者:王亮作者:Polly 团队原文:http://t.cn/EhZ90oq声明:我翻译技术文章不是逐句翻译的,而是根据我自己的理解来表述的(包括标题).其中可能会去除一些不影响理解但本人实在不知道如 ...
- MaxCompute教程
MaxCompute全套攻略:https://blog.csdn.net/qq_35394891/article/details/82943894 [2019年大数据福利推荐]MaxCompute教程 ...
- 【学习总结】GirlsInAI ML-diary day-14-function函数
[学习总结]GirlsInAI ML-diary 总 原博github链接-day14 认识函数function 函数相当于一个固定的公式,一个映射.有输入,有输出. 1-python内置函数 max ...