首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Rafy 领域实体框架 - 树型实体功能(自关联表)

在 Rafy 领域实体框架中,对自关联的实体结构做了特殊的处理,下面对这一功能进行讲解。 场景 在开发数据库应用程序时,往往会遇到自关联表的场景。...而针对这样的场景,许多ORM框架都不做默认的处理,开发者往往每次都要做重复的工作:建立类似结构的表,编写关系处理代码,编写查询代码……而这种场景经常会出现,所以 Rafy 实体框架中,默认就支持了树型实体的一系列功能...功能及使用说明 在 Rafy 中的树型实体功能,只需开发者使用一行代码为指定的实体打开这个功能,框架会自动完成以下工作: 自动添加实体的自引用关系。自动生成数据库自关联表。...自动生成数据库自关联表 运行程序后,该实体对应的表将会自动添加两个字段:TreeIndex、TreePId,如下图: ?...所以这个属性的值非常重要,只能由框架来自行维护,而不能由开发者来设置。

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

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

    1】.LINQ框架的主要设计模型 到了这里我们似乎隐隐约约的能看见LINQ的原理,它不是空中花园,它是有基础的。...在ADO.NET EntityFrameWork、Linq to SQL框架中有很多值得我们探索的对象模型。...学生集合类型主要就是用来容纳学生实体,集合类型提供一系列的方法可以对这个集合进行连续的操作,很常用的就是筛选操作。...编辑器负责对LINQ进行处理而不是CLR负责对LINQ进行处理,编辑器将LINQ处理成框架所实现的基本接口集。记住,LINQ是语法糖层面的,它不是C#不是VB.NET更不是CLR的基本内核的支持。...2.6.整体梳理LINQ的框架原理 通过上面的详细的介绍我们对LINQ的框架基本掌握了,如果只是使用它其实是很简单的,只要熟悉LINQ的查询语法就行了,但是我想我们每个程序员都有很强的好奇心,想搞懂框架的设计原理

    2.1K30

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

    使用LINQ查询自定义的数据源需要借助LINQ框架为我们提供的IQueryable、IQueryProvider两个重量级接口。后面的文章将讲解到,这里先了解一下。...扩展方法对LINQ的支撑非常重要,很多对象原本构建与.NET2.0的框架上,LINQ是.NET3.0的技术,如何在不影响原有的对象情况下对对象进行添加行为很有挑战。 ...比如传统的WINFORM框架,我们可以将ORM实体作为窗体的控件数据源,让ORM实体与窗体的控件之间形成自然的映射,包括对赋值、设置值都很方便。...但是这样的实体经过序列化后到达服务层,然后经过检查进入到BLL层接着进入到DAL层,这个时候ORM框架需要使用该实体作相应的数据库操作。那么我们如何使用.NET3.0的特性为ORM添加其他的行为呢?...在.NET3.5框架的System.Linq.Expression命名空间中引入了以Expression抽象类为代表的一群用来表示表达式树的子对象集。

    1.9K31

    .NET深入解析LINQ框架(六:LINQ执行表达式)

    一:LINQ执行表达式 在研究LINQ的过程中,参考了很多技术文章还有技术书籍,毫无疑问的是Linq to Provider的调用入口都是将Lambda表达式解析成Expression表达式对象,...我们都是直接使用LINQ作为查询接口,VS在最后编译的时候负责对LINQ的语法进行解析并且翻译成对应的扩展方法调用。...我们忽视一个重要的环节,就是VS对LINQ进行解析翻译的时候是会执行LINQ表达式的,这点非常重要。...追求优雅代码的同志很不希望在一个既有LINQ查询又带有链式查询的方法中用两种查询方式,如果LINQ能满足大部分的查询功能那最完美; 为了说明LINQ在编译时会被VS执行,我们用LINQPad工具看一下便知...将界面上的查询实体传入到数据访问层之后: 1 public List GetList(Truck truckModel) 2 { 3 using (KJtest0817Entities

    1.3K10

    ETL(十):异构关联(联接器转换组件的使用)

    1、同构关联和异构关联的区别 注:同构关联的表出自同一个地方,比如说两张表都来自Oracle数据库;异构关联的表出自不同地方,比如说一张表来自Oracle数据库,一张表来自于MySQL数据库。...字段的数据类型:添加一个“f(x)表达式转换”组件,并将dept表中的所有字段,都传递给“f(x)表达式转换”组件; ④ 双击“f(x)表达式转换”组件,进行数据类型的转换; ⑤ 添加一个“联接器转换...”组件,并将各自的字段都传递到“联接器转换”组件中; ⑥ 双击“联接器转换”组件:设置一个关联条件; ⑦ 将“联接器转换”组件中的字段都传递给目标表; ⑧ 使用CTRL +...同时保存创建的工作流; ③ 通过任务启动工作流; ④ 上述操作会自动打开M客户端; ⑤ 最后再去目标表中查看最终生成的数据,可以看到已经将mysql中的dept表和oracle中的emp表关联到一起了

    67330

    Rafy 领域实体框架简介

    按照最新的功能,更新了最新版的《Rafy 领域实体框架的介绍》,内容如下: 本文包含以下章节: 简介 特点 优势 简介 Rafy 领域实体框架是一个轻量级 ORM 框架。...与一般的 ORM 框架不同的是,它不只关注于一般性的面向对象实体与关系数据库的映射,而是更关注于富领域模型(聚合实体)与关系数据库的映射。...实体基类的设计支持关系的延迟加载、自动冗余属性、大对象属性、数据绑定、树型实体等。详情见:领域实体。 实体使用了自定义属性系统(托管属性框架)。...领域服务是跨组合实体的业务逻辑的封装体,也是 SOA 架构的基础。详情见:领域服务。 插件化(组件化)架构 Rafy 实体框架相对于传统的 ORM 框架,一个很大的不同在于支持插件化的架构。...稳定、质量有保障 领域实体框架的代码行有 5 万多行。为了保证框架的稳定性及运行质量,我们为框架编写了 700 多个单元测试,以测试框架的各个功能是否运转正常并保证兼容性。

    1.4K70

    ORM查询语言(OQL)简介--高级篇:脱胎换骨

    一、OQL之前生 1.1,内容回顾:     OQL是我设计用来处理PDF.NET开发框架的ORM查询的,因此叫做ORM查询语言。...OQL的原理基于2大特性: 表达式的链式调用   属性的实例调用 OQL支持4大类数据操作 数据查询: 单实体类(单表)查询 多实体类(多表)关联查询 数据修改 更新数据 删除数据 统计、聚合运算...但是,在一些必须检查存在性的情况中,使用联接会产生更好的性能。否则,为确保消除重复值,必须为外部查询的每个结果都处理嵌套查询。所以在这些情况下,联接方式会产生更好的效果。...Name = 'Chainring Bolts'; 1.2.3,OQL数据插入     尽管OQL可以支持实体类的批量更新与删除,但没有支持实体类的插入,原因是对单个实体类而言,可以直接调用EntityQuery...尽管EF是PDF.NET ORM 的强劲对手,但 PDF.NET ORM的查询语言OQL,相对于EF的查询语言Linq,还是有自己独立的特色,OQL比Linq更接近SQL,Linq是VS的语法糖,本质上

    2.6K70

    ADO.NET 实体框架概述

    实体框架组件 实体框架使开发人员可以编写更少的数据访问代码,减少维护,将数据结构抽象化为更易于开展业务(标准化程度较低)的方式,并且有利于数据的持久性。...当与 LINQ to Entities结合使用时,由于实体框架从概念模型中生成强类型化类,还有助于降低编译时错误的数量。实体框架生成开发人员能够依据其编写代码的概念模型。...开发人员的另一种方法是通过具有实体 SQL 的 ObjectQuery 对象或 LINQ to Entities 来使用对象服务。...例如,您可能在概念模型中有一个实体,该实体实际上从数据库的多个表中派生其数据。概念模型和逻辑模型可按一对一的关系来关联实体。然而,EDM 的功能是它不必以一对一的方式链接实体。...2、2008年3月份 LINQ 的标准查询操作符:http://msdn.microsoft.com/zh-cn/magazine/cc337893.aspx 3、2008年5月份 实体框架问题与解答

    1.4K50

    一步一步学Linq to sql(二):DataContext与实体

    DataContext  DataContext类型(数据上下文)是System.Data.Linq命名空间下的重要类型,用于把查询句法翻译成SQL语句,以及把数据从数据库返回给调用方和把实体的修改写入数据库...,那么首先我们需要定义映射到数据表的实体。...定义实体类 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.Linq.Mapping...            {                 Console.WriteLine("姓名为:{0}在城市{1}",ct.顾客名,ct.城市);             } 使用DataContext类型把实体类和数据库中的数据进行关联...总结   看到这里,你可能会觉得手工定义和数据库中表对应的实体类很麻烦,不用担心,VS提供了自动生成实体类以及关系的工具,工具的使用将在以后讲解。

    84520

    C#3.0新增功能09 LINQ 标准查询运算符 04 运算

    Enumerable.TakeWhileQueryable.TakeWhile 07 联接运算 联接两个数据源就是将一个数据源中的对象与另一个数据源中具有相同公共属性的对象相关联。...当查询所面向的数据源相互之间具有无法直接领会的关系时,联接就成为一项重要的运算。在面向对象的编程中,这可能意味着在未建模对象之间进行关联,例如对单向关系进行反向推理。...如果你具有一个 City 对象列表,并且要查找每个城市中的所有客户,则可以使用联接运算完成此项查找。 LINQ 框架中提供的 join 方法包括 Join 和 GroupJoin。...GroupJoin 方法在关系数据库术语中没有直接等效项,但实现了内部联接和左外部联接的超集。 左外部联接是指返回第一个(左侧)数据源的每个元素的联接,即使其他数据源中没有关联元素。...(C#) 匿名类型 构建联接和叉积查询 join 子句 如何:使用组合键进行联接 如何:联接不同文件的内容 (LINQ) (C#) 如何:对 join 子句的结果进行排序 如何:执行自定义联接操作 如何

    9.7K20

    信息安全技术 实体鉴别保障框架

    声明本文是学习信息安全技术 实体鉴别保障框架....下载地址 http://github5.com/view/1676而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们实体鉴别保障框架 前言本文件按照GB/T 1.1-2020《标准化工作导则...实体鉴别保障框架 范围本文件确立了实体鉴别的保障框架,规定了各参与方角色的职责、实体鉴别的主要流程环节以及实体鉴别保障等级的类别和等级划分原则,并规定了实体鉴别保障所需的管理要求。...本文件适用于实体鉴别服务的安全测试和评估,并为其它实体身份鉴别相关标准的制定提供依据和参考。 实体鉴别保障框架 规范性引用文件下列文件中的内容通过文中的规范性引用而构成本文件必不可少的条款。...图片延伸阅读 更多内容 可以点击下载 信息安全技术 实体鉴别保障框架. http://github5.com/view/1676进一步学习联系我们DB35-T 981-2010 玻璃鳗配合饲料 福建省.

    76760

    Rafy 框架 - 大批量导入实体

    某些场景下,开发者希望能够大批量地把实体的数据导入到数据库中。虽然使用实体仓库保存实体列表非常方便,但是其内部实现机制是一条一条的保存到数据库,当实体的个数较多时,效率就会很低。...repo.Save(books); 需要把最后一行使用仓库保存实体列表,修改为创建导入器来保存实体列表: //创建一个批量导入器进行保存。...也就是说,批量导入父实体时,同时也会批量导入父实体下的所有子实体。 批量导入不但支持添加新实体,同时也支持批量更新、批量删除。使用方法与使用仓库保持一致。...新增大量实体时,实体的 Id 生成 一般情况下,使用仓库保存一个新增的实体时,仓库会使用数据库本身的机制来为实体生成 Id,在 SQLServer 中是使用 IDENTITY 列,在 ORACLE 中则是使用每个表对应的...但是,批量导入大量新实体时,为了性能上的考虑,则需要一次性为需要保存的所有新实体统一生成 Id。

    1.3K80

    C#学习笔记六: C#3.0Lambda表达式及Linq解析

    join子句支持以下3种常见联接方式。 内部联接:元素的链接关系 必须同时满足两个数据源,类似于SQL语句中的inner join子句。 分组联接:包含into子句的join子句。...左外部联接:元素的链接关系必须满足联接中的左数据源,类似于SQL语句中的left join子句。...内部联接:join子句的内部联接要求两个数据源都必须存在相同的值,即两个数据源都必须存在满足联接关系的元素。 示例 下面创建一个查询表达式query。...最终,查询表达式的结果包含4个元素(0、2、4和6) 分组联接:join子句的分组联接包含into子句的join子句的链接。它将左数据源与右数据源的元素一次匹配。左数据源的所有元素都出现在查询结果中。...感谢@浪子哥 给的建议, 现在加上两张表的关联多条件查询, 只有Linq和Lambda表达式 今天自己又参考园里大神的一些帖子自己写了一个两张表关联查询的Linq及Lambda表达式的Demo, 大家可以看下

    8.5K110

    .NET深入解析LINQ框架(五:IQueryable、IQueryProvider接口详解)

    环路执行对象模型、碎片化执行模型(假递归式调用) 这个主题扯的可能有点远,但是它关系着整个LINQ框架的设计结构,至少在我还没有搞懂LINQ的本意之前,在我脑海里一直频频出现这样的模型,这些模型帮助我理解...其实理解这些所谓的设计模型后将大大开阔我们的眼界,毕竟研究框架是要研究它的设计原理,它的存在必然是为了解决某一类问题,问题驱动它的设计模型。...详情可以参见本人的“NET深入解析LINQ框架(四:IQueryable、IQueryProvider接口详解)”一文; 3】.LINQ查询表达式和链式查询方法其实都是空壳子 LINQ的真正意图是在方便我们构建表达式树...(ExpressionTree),手动构建过表达式树的朋友都会觉得很麻烦(对动态表达式有兴趣的可以参见本人的“.NET深入解析LINQ框架(三:LINQ优雅的前奏)”一文),所以我们可以通过直接编写Lambda...ORM一直是我们比较喜欢去写的框架,这里就使用自定义的IQueryable来查询相应的对象实体。首先我们需要继承IQueryable接口来让LINQ能查询我们自己的数据上下文。

    1.1K30
    领券