首页
学习
活动
专区
圈层
工具
发布

Rafy 领域实体框架设计 - 重构 ORM 中的 Sql 生成

前言 Rafy 领域实体框架作为一个使用领域驱动设计作为指导思想的开发框架,必然要处理领域实体到数据库表之间的映射,即包含了 ORM 的功能。...但是过程中,一直没有修改最核心的 Sql 语句生成模块。随着应用的不断深入,遇到的场景越来越多,需要生成复杂 Sql 语句的场景也越来越多。...而这些场景如果还让开发人员自己去编写复杂 Sql 语句,不但框架的易用性下降,而且由于写了过多的 Sql 语句,还会让开发人员面向领域实体来开发的思想减弱。...EntityQuery 层中的类型实现了 IQuery 中对应的接口,并使用领域实体的相关 API 来实现从实体到表、实体属性到列的转换。...重构的同时,我们为能想到的场景都编写了测试用例: 目前,框架版本也升级到了 2.23.2155。 有兴趣的同学,了解、下载最新的框架,请参考:《Rafy 领域实体框架发布!》。

2.4K70

EF Core关系配置

普通集合的版本(IEnumerable)是在内存中过滤(客户端评估),而IQueryable版本则是把查询操作翻译成SQL语句(服务器端评估) IQueryable books = ctx.Books...执行实体相关查询原生SQL语句 如果要执行的原生SQL是一个查询语句,并且查询的结果也能对应一个实体,就可以调用对应实体的DbSet的FromSqlInterpolated()方法来执行一个查询SQL...SQL EFCore如何跟踪实体数据变化 快照更改跟踪:首次跟踪一个实体的时候,EF Core 会创建这个实体的快照。...DbContext会根据跟踪的实体的状态,在SaveChanges()的时候,根据实体状态的不同,生成Update、Delete、Insert等SQL语句,来把内存中实体的变化更新到数据库中。...; Tips:一般只有在编写不特定于某个实体类的通用框架的时候,由于无法在编译器确定要操作的类名、属性等,所以才需要编写动态构建表达式树的代码。

63110
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    .NET面试题系列 - LINQ to SQL与IQueryable

    LINQ to Object的数据源总是实现IEnumerableT>(所以不如叫做LINQ to IEnumerableT>),相对的,LINQ to SQL的数据源总是实现IQueryablesql语句(不需要返回值,用于DDL或delete语句)和通过执行Sql语句,返回若干实体的功能(用于select语句)。...而我们还需要知道目标实体类的类型名称Staff,所以我们的解析方法还需要接受一个泛型T。 另外,由于我们的解析方法很有可能是递归的(因为要解析表达式树),我们的输出还需要用ref加以修饰。....Where(t => t.Name == "Frank"); 此时我们用IQueryableT>可以得出正确的结果(test只有1笔输出),但使用自己的查询提供器,获得的SQL却是错误的(第一个Sex...但是IQueryable的优势是它有表达式树,所有对于IQueryableT>的过滤,排序等操作,都会先缓存到表达式树中,只有当真正发生遍历的时候,才会将表达式树由IQueryProvider执行获取数据操作

    2K10

    Net和T-sql中的日期函数操作

    net中的日期函数代码:  代码 数据库的日期函数: 函数 参数/功能 GetDate( ) 返回系统目前的日期与时间 DateDiff (interval,date1,date2) 以interval...DatePart (interval,date) 返回日期date中,interval指定部分所对应的整数值 DateName (interval,date) 返回日期date中,interval指定部分所对应的字符串名称...参数 interval的设定值如下: 值 缩 写(Sql Server) (Access 和 ASP) 说明 Year Yy yyyy 年 1753 ~ 9999 Quarter Qq q 季...1 ~ 4 Month Mm m 月1 ~ 12 Day of year Dy y 一年的日数,一年中的第几日 1-366 Day Dd d 日,1-31 Weekday Dw w 一周的日数,一周中的第几日...1-7 Week Wk ww 周,一年中的第几周 0 ~ 51 Hour Hh h 时0 ~ 23 Minute Mi n 分钟0 ~ 59 Second Ss s 秒 0 ~ 59 Millisecond

    1.6K60

    使用ORM框架,必须迁就数据库的设计吗?

    如果是简单,lz的这套语法/函数还是略显复杂。 (4)对于一款面向.NET的ORM框架,如果不兼容 IQueryable 接口是一种相当大的遗憾。...我说几条EF的问题,不知道你的产品能否解决:  - 对于泛型实体的支持,假设我要设计一个考试系统: C# code class QuestionsT> where T : QuestionBase...--由于PDF.NET框架是在实际商业产品中的应用,所以维护一直在进行,功能扩展和Bug修复一直在进行中; (3)ORM的框架众多,lz的产品优势在哪里?定位简单还是功能强大?...--正因为有不同数据库的方言问题,所以框架使用SQL-MAP技术,将那些需要高效执行的、数据库特性的SQL单独写到配置文件中,当需要切换数据库的时候, 仅仅替换这个SQL配置文件即可(SQL-MAP配置文件...比如自定义函数和SQL类型等等 --PDF.NET的实体类本着从简的原则,实体类没有引入复杂关系的概念,遇到这些复杂的查询,可以使用SQL-MAP功能,它可以将DataReader的结果读入实体类中;

    2.3K90

    一个库帮你快速实现EF Core数据仓储模式

    值得推荐的.NET ORM框架 对于还不知道怎么选择.NET ORM框架的同学可以看下面这两篇文章,希望对你会有所帮助。...16个值得推荐的.NET ORM框架 .NET ORM框架使用情况统计 数据仓储(Repository)介绍 Repository(仓储)是DDD(领域驱动设计)中的经典思想,可以归纳为介于实际业务层(...提供了带有数据库事务支持的通用存储库。 拥有所有必需的方法,以任何你想要的方式查询数据,而无需从存储库获取IQueryable。...支持SpecificationT>模式,使你能够动态构建查询,即延迟查询构建。 具有针对你的查询的数据库级投影支持。 支持针对你的关系型数据库运行原始SQL命令。...支持选择是否要跟踪你的查询实体/实体。 支持在确实需要时重置你的EF Core DbContext状态。 具有完整的单元测试支持。 支持分页、原始SQL查询支持复杂类型和原始类型。

    51810

    【愚公系列】2023年02月 .NETC#知识点-使用控制台手搭webapi框架

    文章目录 前言 一、使用控制台手搭webapi框架 1.配置文件 2.控制台配置 二、EFCore框架DBSet配置详解 1.实体统一配置 2.实体继承统一接口 3.获取程序集所有类 4.批量注入模型类到...EF中 三、EFCore框架表配置详解 1.配置基类, 2.实体表统一配置 3.DBContext中应用配置 四、仓储配置 1.仓储基类 2.仓储实现类 五、Autofac配置 1.注入DBContext...LibraryDbContext和EFCoreEleganceUseEFCoreModule,下面着重详解 二、EFCore框架DBSet配置详解 1.实体统一配置 EF实体继承统一的接口,方便我们反射获取所有...EF实体,接口可以设置一个泛型,来泛化我们的主键类型,因为可能存在不同的表的主键类型也不一样。...DBContext中作为DBSets,再也不需要一个个写DBSet了,可以用过DbContext.Set()获取用户的DBSet。

    1.7K10

    DDD理论学习系列(12)-- 仓储

    举个例子:我们在仓储中定义了一个方法GetAllActiveUsers()与sql语句select * from users where isactive = 1或var users =db.Users.Where...换句话说,ORM负责将代码中定义的对象和关系映射到数据库的表结构中去,并在进行数据访问时再将表数据映射到代码中定义的对象,借助ORM我们不需要去手动写SQL语句就可以完成数据的增删改查。...IQueryable Vs IEnumerable 在定义仓储方法的返回值时,我们可能会比较疑惑,是应该直接返回数据(IEnumerable)还是返回查询(IQueryable)以便进行进一步的细化查询...返回IEnumerable会比较安全,但IQueryable提供了更好的灵活性。事实上,如果使用IQueryable作为返回值,我们仅提供一种读取数据的方法即可进行各种查询。...比如,在实体中我们一般使用IsActive或IsDeleted属性来表示软删除,而一旦实体中的某条数据被删除,那么UI中基本不会再显示这条数据,那对于实体的查询都需要包含类似Where(c=> c.IsActive

    2.2K70

    金三银四面试:C#.NET面试题中高级篇5-Linq和EF

    实体框架EF是http://ADO.NET中的一组支持开发面向数据的软件应用程序的技术,是微软的一个ORM框架。...ORM指的是面向对象的对象模型和关系型数据库的数据结构之间的互相转换。 (表实体跟表之间的相互转换) ORM框架有很多,EF框架是ORM框架的其中一种,是实现了ORM思想的框架。...提升从数据库中拿数据的速度,可以参考以下几种方法: 1).在数据库中的表中定义合适的索引和键 2).只获得你需要的列(使用ViewModel或者改进查询)和行(使用IQueryable)...12.请说明EF中映射实体对象的几种状态? Detached:该实体未由上下文跟踪。...Unchanged:实体将由上下文跟踪并存在于数据库中,其属性值与数据库中的值相同。 Added:实体将由上下文跟踪,但是在数据库中还不存在。

    5K30

    .net 温故知新:【10】.NET ORM框架EFCore使用入门之CodeFirs、DBFirst

    目的在于通过要点的梳理最后串联起整个跨平台框架。之前的几篇算是把框架重要设计和框架重要知识点复习了,当然什么系统都可能使用到ORM框架。...EFCore入门 在上面的EFCore介绍中我们又看到了提供程序描述,之前文章多次提到这个提供程序是.net框架中随处可见的,也就是通过这些不同的提供程序实现扩展和适配。...Iqueryable的作用和数据延迟加载,在我们查询数据的时候列表数据以Iqueryable类型返回,如果我们不是调用获取结果api,则不会立即查询数据库,而是等到使用tolist()、count()、...这样有利于我们在代码中复用Iqueryable,比如不同的if条件拼接后组成不同的查询语句。 EFcore 缓存。...AsNoTracking使用,EFCore默认会跟踪实体,也就是保存在内存中,用于更新删除等操作。如果只是查询数据而不用跟踪则使用AsNoTracking查询。 并发控制。 .....

    3.9K30

    .NET深入解析LINQ框架(二:LINQ优雅的前奏)

    在ADO.NET EntityFrameWork、Linq to SQL框架中有很多值得我们探索的对象模型。...在使用IEnumerableT>和IQueryableT>之间的区别是什么?如何很好的理解这两者在LINQ的整个框架中的关系。...2.4.深入IQueryable、IQueryableT>、Queryable(LINQ to Provider框架的入口) IQueryable接口是提供给我们来实现自定义数据源用的,为了支持强类型的数据源集合我们直接使用...IQueryableT>接口,当我们使用LINQ来查询IQueryableT>接口时查询表达式会被直接编译成对应的Queryable静态类中的对应的静态扩展方法。...LINQ查询表达式最后是调用的链式查询方法,这些方法都是在静态类中定义好的,IEnumerableT>类型是直接的使用匿名方法调用执行,而IQueryableT>是使用人工解析的方式进行的,也就是自定义数据源

    2.4K30

    (PDF.NET框架实例讲解)将任意复杂的SQL查询映射成实体类

    通常情况下我们的ORM框架都是将单表或者视图映射成一个实体类,有时候也会将存储过程映射成实体类,如果处于系统移植性的考虑,你不想写存储过程,那这些复杂的SQL查询怎么映射成实体类?...实际上,不管是单表,视图,存储过程,SQLSERVER的表值函数,自定义的SQL查询,甚至是任意复杂的SQL查询,都可以用一个SQL语句来表示,只要我们的ORM框架能够实现将SQL语句的查询结果映射成实体类...然后,弹出一个新窗口,进行生成实体类的有关设置: ? 注意勾选“SQL查询的有效性”,并输入要映射的实体类名称等信息,然后点击“确定”。 ?...除了可以通过本文说的方式将SQL语句映射到实体类,还可以通过PDF.NET内置的SQL-MAP技术来实现实体类映射,就像iBaits那样,但比iBaits简单很多,详细内容,请参看: PDF.NET数据开发框架...之SQL-MAP使用存储过程 注:本文所说的自定义查询在PDF.NET3.5以后方可以支持,实例代码需要在PDF.NET 4.1以上支持,PDF.NET本身仅需要.net 2.0支持,框架的最新版本没有公开发布

    3K80
    领券