小白学习之Code First(五)
Fluent API:另一种配置实体类的方式,它比DataAnnorations提供了更多的配置
其中EntityTypeConfiguration这个类提供了重要的属性、方法来配置对应的实体类,可以通过protected override void OnModelCreating(DbModelBuilder modelBuilder)的参数获取EntityTypeConfiguration<StudentInfo> studentInfoEntityConfig=new modelBuilder.Entity<StudentInfo>();列出其中一些方法:
HasEntitySetName:配置要用于此实体类型的实体集名称。 只能为每个集中的基类型配置实体集名称。
HasKey:配置此实体类型的主键属性。
HasMany:实体类型配置一对多关系。
HasOptional:实体类型配置可选关系。 实体类型的实例将能保存到数据库,而无需指定此关系。数据库中的外键可为 null。
HasRequired:配置必须的关系,如果配置关系,实体无法保存到数据库中,外键不能为空。
HasTableAnnotation:在实体映射到的表的模型中设置注释。 稍后可在处理表时(如创建迁移时)使用此注释值。
Ignore:从模型中排除某个属性,使该属性不会映射到数据库。
Map:允许与此实体类型映射到数据库架构的方式相关的高级配置。 默认情况下,任何配置都还会应用于从此实体类型派生的任何类型。
MapToStoredProcedures:将此类型配置为使用插入、更新和删除的存储过程。 将使用过程名称和参数名称的默认约定。
Property:配置在此类型上定义的属性。
ToTable:配置此实体类型映射到的表名。
实体:
public class StudentInf
{
public int SID { get; set; }
public string SName { get; set; }
public int Age { get; set; }
public string Address { get; set; }
public DateTime BirthDay { get; set; }
public ClassInf ClassInf { get; set; }
}
public class ClassInf
{
public int CID { get; set; }
public string CName { get; set; }
public virtual ICollection<StudentInf> StudentInfs { get; set; }
}
配置:
(图1)
(图2)
(图3)
public CSContext1():base("name=ConnStr")
{
}
public DbSet<ClassInf> ClassInfs { get; set; }
public DbSet<StudentInf> StudentInfs { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
EntityTypeConfiguration<StudentInf> SConfig = modelBuilder.Entity<StudentInf>();
EntityTypeConfiguration<ClassInf> CConfig = modelBuilder.Entity<ClassInf>();
//将实体映射成自定义名称的表 图1
//SConfig.ToTable("Student");
//CConfig.ToTable("Class");
//设置主键、复合主键
SConfig.HasKey(S => new {S.SID,S.SName});
CConfig.HasKey(c => c.CID);
//拆分表 图2
//SConfig.Map(m => {
// m.Properties(p => p.ID);
// m.Properties(p => p.SName);
// m.ToTable("StudentMaster");
//}).Map(m => {
// m.Properties(p => p.ID);
// m.Properties(p => p.Address);
// m.Properties(p => p.Age);
// m.Properties(p => p.BirthDay);
// m.ToTable("StudentDetial");
//});
//设置列属性 图3
SConfig.Property(s => s.Address).HasColumnName("地址").HasColumnOrder().HasColumnType("Nvarchar").IsUnicode(true).IsOptional().HasMaxLength();
//设置存储过程 图3
CConfig.MapToStoredProcedures(m => m.Update(u =>
{
u.HasName("Class_procedure").Parameter(c => c.CName, "ClassName");
}));
Database.SetInitializer(new DropCreateDatabaseIfModelChanges<CSContext1>());
base.OnModelCreating(modelBuilder);
}
MapToStoredProcedures 上图中只自定义了Update的存储过程,而insert和Delete的存储过程自动生成默认的
static void Main(string[] args)
{
var context = new CSContext1();
context.StudentInfs.ToList();
Console.WriteLine("OK");
Console.ReadKey();
}
小白学习之Code First(五)的更多相关文章
- Python小白学习之路(五)—【类和对象】【列表】【列表相关功能】
类和对象 (简单的了解一下这个概念,初步有个印象,这个概念很重要,后面会着重讲) 类:具有相同属性和方法的对象的集合: 对象:万物皆对象: 概念很抽象(每当我看不到概念的时候,我就会通过举例来理解) ...
- 小白学习之Code First(四)
code first :约定大于配置(通过配置实体重写约定) 通过两种方式配置实体:DataAnnotations Fluent Api System.ComponentModel.Data ...
- 小白学习之Code First(三)
上下文Context类中的base构造器的几个方法重置(1.无参 2.database name 3 . 连接字符串) 无参:如果基类base方法中无参,code first将会以 :{Namespa ...
- 小白学习之Code First(二)
Code First约定: 注:EDMX模板 (SSDL:存储模型=>数据库表 ,CSDL:概念模型=>实体,C-S模型=>存储和概念模型之间的映射关系) System.Data.E ...
- 小白学习之Code First(一)
1.根据自己的理解,Code First :通过实体类和相关配置生成对应的数据库,实现实体和数据库的映射关系,或通过实体类和相关配置与已经生成的实体与已经存在的数据库搭建映射关系 例: 实体类:Stu ...
- 【Unity Shaders】学习笔记——SurfaceShader(五)让纹理动起来
[Unity Shaders]学习笔记——SurfaceShader(五)让纹理动起来 转载请注明出处:http://www.cnblogs.com/-867259206/p/5611222.html ...
- Nodejs学习笔记(十五)--- Node.js + Koa2 构建网站简单示例
目录 前言 搭建项目及其它准备工作 创建数据库 创建Koa2项目 安装项目其它需要包 清除冗余文件并重新规划项目目录 配置文件 规划示例路由,并新建相关文件 实现数据访问和业务逻辑相关方法 编写mys ...
- [转]Nodejs学习笔记(十五)--- Node.js + Koa2 构建网站简单示例
本文转自:https://www.cnblogs.com/zhongweiv/p/nodejs_koa2_webapp.html 目录 前言 搭建项目及其它准备工作 创建数据库 创建Koa2项目 安装 ...
- Nodejs学习笔记(十五)—Node.js + Koa2 构建网站简单示例
前言 前面一有写到一篇Node.js+Express构建网站简单示例:http://www.cnblogs.com/zhongweiv/p/nodejs_express_webapp.html 这篇还 ...
随机推荐
- Kafka send问题
kafka 在send之后不会立即把消息发送到broker.会把消息发到producer所在电脑内存里,后端的IOThread会扫描内存,并从中取出消息进行消费. 在调用close()或者flush( ...
- STM32F4时钟配置库函数详解
在STM32中,所有的应用都是基于时钟,所以时钟的配置就尤为重要了,而不能仅仅只知道使用默认时钟. STM32F4的时钟树如上图所示,HSE为外部接入的一个8M的时钟,然后再给PLL提供输入时钟,经过 ...
- java之JIT(Just in time)
Java程序最初是通过解释器进行解释执行的,当虚拟机发现某个方法或代码块运行的特别频繁时,会把这些代码认定为“热点代码”(Hot Spot Code).为了提高热点代码的执行效率,在运行时,虚拟机会把 ...
- [小tips]使用vscode,根据vue模板文件生成代码
本着苍蝇虽小也是肉的精神...... 目标: 我们希望每次新建.vue文件后,VSCODE能够根据配置,自动生成我们想要的内容. 方法: 打开VSCODE编辑器,依次选择"文件 -> ...
- java解压缩.gz .zip .tar.gz等格式的压缩包方法总结
1..gz文件是linux下常见的压缩格式.使用 java.util.zip.GZIPInputStream即可,压缩是 java.util.zip.GZIPOutputStream public s ...
- elasticsearch5.x安装中一些问题的解决办法
1.root超级用户不能正常启动 由于elasticsearch2.0版本以后不能使用root来启动,所以需要创建一个普通用户来启动. [root@bogon ~]# groupadd elastic ...
- 【BZOJ3992】【SDOI2015】序列统计 EGF+多项式快速幂+循环卷积
如果是求$n$个数之和在模$m$意义下为$x$,那么做法是显然的. 但是这道题问的是$n$个数之积在模m意义下为$x$,那么做法就和上面的问题不同. 考虑如何把乘法转换成加法(求log): 题目中有一 ...
- tensorflow基础篇-1
1.使用占位符和变量 import tensorflow as tf import numpy as np #-----创建变量并初始化----------- def first(): my_var= ...
- PHP中 LFI Local File Include,本地文件包 漏洞
在allow_url_include=On就是远程文件包含了,假设这里为off,那就只能本地包含了. 1. 包含上传文件 只要目标服务器支持上传,不管是jpg,txt,gif等都可以,在其 ...
- css自动适应宽度
.itemContent { background-color:#F0F0F0; padding:3px 11px 11px 11px; text-align:justify; text-justif ...