首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

EF简介

EF:EF是 asp.net的一套ORM框架....一、当添加完EF实体之后: 1、系统会自动生成一个(对应ef模块名.content.tt文件),  这个模版是帮助我们生成ef访问上下文的,里面有一个数据库实体,上面这个例子是TestEntities实体...2、系统还会生成一个(对应ef模块名.tt文件),这个模版是帮助我们生成一个数据库对应的表实体. 3、另外需要注意一点,系统还会生成一个(对应ef模块名.Designer.cs文件)这个文件在ef4.0...之后里面是没有代码的,但是在ef4.0的时候是有的,那个时候里面存放的是数据库上下文和数据库对应的表实体,如果你需要使这个(对应ef模块名.Designer.cs文件)文件里面的文件重现,你只需要找到对应的数据库模型...2、 //利用EF像数据库中添加一条数据 //first step:创建访问数据库的统一入口.创建EF的上下文 TestEntities dbContext

1.4K80

EF原理

EF简介 实体框架(Entity Framework)简称EF,是微软以ADO.NET为基础所发展出来的对象关系对应(O/R Mapping)解决方案。...ORM O/R Mapping 是EF中非常重要的一个思想,官方解释为:ORM指的是面向对象的对象模型和关系型数据库的结构之间的相互转换。...上图也很好的解释了EF的工作原理,我们所做的增删改查操作通过ObjectContext上下文传到ORM,通过实体的变化映射到关系表,从而实现对数据库的操作。...那么在EF中是如何实现对数据的增删改查呢?...2.Model First 是先利用某些工具(如VS的EF设计器)设计出可视化的实体数据模型及他们之间的关系,然后再根据这些实体、关系去生成数据库对象及相关代码文件。

73410

EF 约定介绍

当前环境为EF Code First开发模式中 一、EF默认约定 1、常用约定 (1)、当没有显示指定实体主键的时候,EF会默认将长得最像Id的属性(且类型为GUID)设为主键 (2)、设计实体时,当一个实体包含一个集合属性...,该集合属性里面的元素是另一个实体时,则默认未一对多关系,即使没有显示的指定一对多的关系,EF会默认的设置主外键(主从)关系 (3)、一对一的实体关系,需要手动设置主从关系 (4)、多对多无载荷关系实体...,EF自动生成中间表,不需要新增实体来表示. (5)、表名默认复数化 2、类型发现约定(Type Discovery) 使用EF开发,往往是以定义一些模型类开始,定义完这些模型类之后,需要让DbContext...则会被当成标识列(Identity Column) 4、关系(外键/导航属性)约定Relationship(Foreign Key/Navigation Properties) Convention EF...modelBuilder.Conventions.Remove(); } } 三、自定义约定 EF 自定义约定

1.6K100

C# 数据操作系列 - 6 EF Core 配置映射关系

映射规则 通过简单的示例,我们可以看到EF的映射规则是什么。基于约定由于配置的原则,EF把实体类当做是一个单数形式的类型描述,把表认为是实体类的集合,所以表名为类名的复数形式。...对于其他属性,EF会自动按照同名的形式映射到数据表中。 对于外键,如果在类里添加了引用类型,而这个引用类型也在EF的上下文中,EF会把这种属性称为导航属性。...如果类型不一致,EF则认为该类设置有误。如果没找到符合名称要求的属性,EF会自己添加一个外键属性。 对于一对一,EF要求导航属性双方都应该具有外键配置。 一对多,EF要求多的一方设置外键。...2.2 Fluent 方式 当我们使用这种方式的时候,会面临一个问题:是新建一个配置类呢,还是在 EF上下文的OnModelCreating方法里统一配置呢?...那么,我们就来看看 通过builder怎么配置映射关系吧: public class ModelEntityConfig : IEntityTypeConfiguration// 基于

2.7K21

EF Core 导航属性配置

当然,如果直接应用这两个配置EF Context的话,在执行 Update-Database 会报以下错误: The child/dependent side could not be determined...之前在说的时候,EF会根据导航属性自动生成一个外键,但是这一条在一对一这里就有点不太起作用了。所以我们必须手动在导航属性的一侧实体类里配置外键,并用 HasForeignKey指定。...EF Core中取消了在映射关系中配置中间表的功能,所以在EF Core中需要一个中间表: public class ManyToManyModelA { public int Id { get...在EF 6中 中间表可以仅存在于关系中,但是在EF Core3 还没有这个的支持。也就是当前文章使用的版本。 5. 附加 在EF的外键约束中,导航属性是默认可空的。...如果要求非空,也就是导航属性的另一端必须存在则需要在配置关系的时候添加: IsRequired() 这个方法也用来声明字段是必须的。这个验证是在EF 调用 SaveChanges 的时候校验的。

3K20

.net EF 新手教程

最近学习了.net 的EF框架,在这里自己总结一下用会的几种操作。 No.1 准备工作 首先先放上数据库的表结构,便于后面的示例操作。...下来我们在项目中添加ADO.NET实体数据模型 模型的内容根据大家的需要进行选择,我在这里选择来自数据库的EF设计器,这样他会帮我自动生成数据库中的EF设计器。...因为我之前创建过这里会显示我之前的连接, 大家可以在这里选择新建连接 因为我使用的 SQL Server,所以这里我选择Microsoft SQL Server,继续 这里根据大家的数据库情况进行选择和配置...配置成功后在选择数据库的位置可以看到我们的数据库,选择需要的数据库后进行确定,我们的准备工作就完成了。...No.2 简单查询 我们先做几个简单的查询体会一下EF的机制 //查询 EFDBEntities efdb = new EFDemo.EFDBEntities

7400

EF Core 数据验证

但是在 Entity Framework Core (以下简称 EF Core )中这些问题全可以解决。在 EF Core 中有两种验证模式,分别是内置模型验证和第三方扩展模型验证。...Id { get; set; } public string Name { get; set; } public int Age { get; set; } } 零、内置模型验证 在 EF...在业务代码中我们调用前面定义的 ExecuteValidation 方法进行验证,如果验证通过就调用 EF Core 的 SaveChange() 方法,如果未通过就调用相应的处理代码,代码片段如下:...这时我们可以使用第三方扩展,在 EF Core 中常用的模型数据验证第三方扩展是 FluentValidation.AspNetCore 。在使用前我们需要在 NuGet 中下载此扩展。...二、总结 本篇文章讲解了 EF Core 数据验证的方法,虽然讲的时 EF Core 的方法,但是同样也适用于 EF6 ,这些内容是常用的,上述部分代码可以在大部分项目中通用。

1.2K20

Linux—ps -ef|grep详解

【Linux】ps -ef|grep详解 Linux下显示系统进程的命令ps,最常用的有ps -ef 和ps aux。这两个到底有什么区别呢?...两者没太大差别,讨论这个问题,要追溯到Unix系统中的两种风格,System V风格和BSD 风格,ps aux最初用到Unix Style中,而ps -ef被用在System V Style中,两者输出略有不同...ps -ef 是用标准的格式显示进程的、其格式如下 其中各列的内容意思如下 UID //用户ID、但输出的是用户名 PID //进程的ID PPID //父进程ID...CMD //命令的名称和参数 ps aux 是用BSD的格式来显示、其格式如下 同ps -ef 不同的有列有 USER //用户名 %CPU //进程占用的CPU百分比...以下这条命令是检查 java 进程是否存在:ps -ef |grep java 字段含义如下: UID PID PPID C STIME TTY

5.9K10
领券