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

ADO.NET 实体框架概述

随着.NET Framework 3.5 SP1和Visual Studio 2008 SP1的正式发布。...ADO.NET 实体框架正式来到开发人员的面前,它使开发人员可以通过对象模型(而不是逻辑/关系数据模型)专注于数据。...EDM 的各个层以 XML 文件形式存在; 实体数据模型 实体框架的核心位于其模型中。实体框架支持表示数据库中的关系架构的逻辑存储模型。关系数据库通常存储数据的方式与应用程序使用数据的方式不同。...通常,这会迫使开发人员按照数据库包含数据的结构检索数据。因此,开发人员通常将数据加载到更适合处理业务规则的业务实体中。在本示例中,以逻辑模型表示关系数据库的构架,业务实体表示概念模型。...实体框架可将针对概念模型编码的所有命令映射到逻辑模型中。 ? 概念模型是使用概念架构定义语言 (CSDL) 在 XML 文件中定义的。CSDL 定义应用程序的业务层所知道的实体和关系。

1.4K50

PDF.NET数据开发框架实体类操作实例

本篇是 PDF.NET数据开发框架实体类操作实例(MySQL) 的姊妹篇,两者使用了同一个测试程序,不同的只是使用的类库和数据库不同,下面说说具体的使用过程。...: /*  * PDF.NET 数据开发框架  * http://www.pwmis.com/sqlmap  */ using System; using System.Collections.Generic...getProperty("Name"); }             set { setProperty("Name", value,50); }         }     } } 与MySQL中定义的用户实体类不同...3,根据这个实体类,我们去MySQL定义一个用户表:tb_user,具体过程省略,注意字段“ID”仍然使用自增列(在PostgreSQL中是 serial 类型,但编辑表类型的时候,发现字段是整数类型,...:  //PostgreSQL 没有 @@IDENTITY 变量,所以无法拿到刚才的自增值,注释掉下面的修改方法 虽然注释了修改实体的方法,但只要手工给ID属性设置值,仍然可以修改实体。

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

    从壹开始前后端分离【 .NET Core2.0 +Vue2.0 】框架之二 || 后端项目搭建

    所有注入的services(此外还包括一些框架已经注册好的services) 在以后写代码的时候, 都可以将它们注入(inject)进去....它可以返回一个带有地址Header的Response, 这个Location Header将会包含一个URI, 通过这个URI可以找到我们新创建的实体数据....CreatedAtRoute第二个参数就是对应着GetProduct的参数列表, 使用匿名类即可, 最后一个参数是我们刚刚创建的数据实体....但是如果body数据的属性有问题, 比如说name没有填写, 或者name太长, 那么在执行action方法的时候就会报错, 这时候框架会自动抛出500异常, 表示是服务器的错误, 这是不对的....验证Model/实体, asp.net core 内置可以使用 Data Annotations进行: //以下不是本系列教程,就看思路即可,不用敲代码 using System; using System.ComponentModel.DataAnnotations

    1.1K20

    PDF.NET数据开发框架实体类操作实例(for PostgreSQL,并且解决自增问题) PDF.NET数据开发框架实体类操作实例(MySQL)

    本篇是 PDF.NET数据开发框架实体类操作实例(MySQL) 的姊妹篇,两者使用了同一个测试程序,不同的只是使用的类库和数据库不同,下面说说具体的使用过程。...注:在PDF.NET SOD框架 5.6.0.1121 之后,框架取消了这一个限制,你仍然可以像在其它数据库中那样使用PostgreSQL的自增列,实体类无需做任何更改。...3,根据这个实体类,我们去PostgreSQL定义一个用户表:tb_user,具体过程省略,注意字段“ID”仍然使用自增列(在PostgreSQL中是 serial 类型,但编辑表类型的时候,发现字段是整数类型...InsertKey=“select @@IDENTITY ”; 注:在PDF.NET SOD框架 5.6.0.1121 之后,框架取消了这一个限制。...,PDF.NET数据开发框架为你自动完成这一切,使得你的SQL语句能够很容易的移植到PostgreSQL。

    1.6K60

    PDF.NET数据开发框架操作MySQL实体类操作实例

    在我们最近的项目中,SQL-MAP使用较多,但是实体类用的很少,实际上,“PDF.NET数据开发框架”的实体类相当强大,下面的测试程序是在MySQL中操作的实例。...1,首先在App.config文件中配置数据库连接字符串: <?xml version="1.0" encoding="utf-8" ?...: /* * PDF.NET 数据开发框架 * http://www.pwmis.com/sqlmap */ using System; using System.Collections.Generic...(此目的也是为了先有实体再有数据表,以便大家领略ORM的正真含义) 4,编写ORM实体类操作的测试代码: using System; using System.Collections.Generic;...new User();             u2.Name = "wang wu";             u2.Age = 20;             //使用EntityQuery 的实例对象方法更新实体

    1K90

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

    前言 Rafy 领域实体框架作为一个使用领域驱动设计作为指导思想的开发框架,必然要处理领域实体到数据库表之间的映射,即包含了 ORM 的功能。...而这些场景如果还让开发人员自己去编写复杂 Sql 语句,不但框架的易用性下降,而且由于写了过多的 Sql 语句,还会让开发人员面向领域实体来开发的思想减弱。...旧代码讲解 最初采用的 Lite ORM 是一个轻量级的 ORM 框架,采用在实体对象上标记特性(Attribute)来声明实体的元数据,并使用链式接口来作为查询接口以方便开发人员使用。...EntityQuery 层中的类型实现了 IQuery 中对应的接口,并使用领域实体的相关 API 来实现从实体到表、实体属性到列的转换。...重构的同时,我们为能想到的场景都编写了测试用例: 目前,框架版本也升级到了 2.23.2155。 有兴趣的同学,了解、下载最新的框架,请参考:《Rafy 领域实体框架发布!》。

    2.1K70

    ASP.NET实体类的作用

    在设计.net程序架构的时候,我更倾向于使用接口而不是实体类在作为函数的参数。...IList FillArticles(SqlDataReader reader)的将SqlDataReader中的结果添加到IList中。  ...articles.Add(article);     }     return articles; } 通过上面这个例子你可以发现,FillArticles方法需要一个SqlDataReader (这是一个实体类...好,现在需求变了,现在数据都存储在了XML文件中,这个时候,我们得到就是XmlDataReader(实际没有这个类型)而不是SqlDataReader了。很不幸,你唯一能做的就是修改这块的源代码。...我们只需要把代码修改成如下的样子即可解决开始遇到的问题了:  private IList FillArticles(IDataReader reader) {     List<Article

    63330

    (PDF.NET框架实例讲解)将存储过程映射为实体类

    PDF.NET数据开发框架可以将表,视图,表值函数,自定义的查询语句和存储过程映射为实体类,在上一篇《(PDF.NET框架实例讲解)将任意复杂的SQL查询映射成实体类 》已经讲解了自定义查询的实体类映射方法...1,使用代码工具,生成实体类代码 具体过程跟“上一篇”文章中的步骤1-4一样,请参见原文。 ?...,参数solution 是varchar(2)类型,参数yield 是int 类型,按照SQL-MAP的语法规则(参见《PDF.NET(PWMIS数据开发框架)之SQL-MAP目标和规范 》),改写成上面的样子...目前,PDF.NET的代码生成器还不能自动生成以上代码,如果要“享受自动生成代码”的过程,则需要使用框架的“SQL-MAP”技术,参见《抽象SQL(参数化)查询 》一文。...注:本文所说的功能需要在PDF.NET 4.1以上支持,PDF.NET本身仅需要.net 2.0支持,框架的最新版本没有公开发布,但已经有不少用户正在项目里面使用,有关框架的详细信息请看官网介绍: http

    932100

    .NET Core中的包、元包与框架

    每一个.NET Core包支持多个.NET运行时,它们代表着不同的框架。这些框架既包括传统的.NET Framework(如net4.6),也包含基于包的新框架,这些新框架建立了定义框架的新模型。...由于这种小范围的变化,验证补丁是否可用所花费的时间,可以限制到对单个库的需求中。...指定一个框架会隐式实现对元包引用,同时也会添加对元包依赖项的引用。这样,元包中的所有类库都能够被IDE智能感知,也可以被打包到你的应用中。...基于包的框架上的API由包来定义,框架本身并不定义任何API。 其次,是这种双向关系中的第二部分,资产选择(asset selection)。包可以包含用于多框架的资产。...上述例子中的1.3.0版本只是为了举例需要,事实上它并不存在。

    1.1K40

    EF实体中的修改

    不推荐方式一: 思路:先从ObjectContext取出实体,然后将前台传过来的DTO属性对应赋值到我们的实体上,然后调用ObjectContext的保证修改方法。...但是这种方式是最不提倡的,因为这样每次修改前都得先将数据查出来,经过SqlProfiler追踪,这么一个操作要对数据库进行两次的连接。这是不可忍受的!...推荐方式二: 思路:无需先查出实体,因为我们知道EF通过ObjectStateManage来控制添加、修改、删除队列以及实体的状态,我们所有可以通过在直接将DTO转化成实体,然后将实体对应的队列中,并...且我们手动的将实体的状态处理好,再调用ObjectContext的保证修改方法,这样就避免了先查询后修改,两次数据库连接的问题了。...schoolDB.Student.Attach(student); //手动修改实体的状态 schoolDB.ObjectStateManager.ChangeObjectState(student

    1.1K10

    使用PDF.NET数据开发框架的实体操作语言OQL构造复杂查询条件

    PDF.NET数据开发框架(Pwmis Data develop Framework,http://www.pwmis.com/sqlmap) 是一套借鉴iBatis、Hibernate、Linq等数据访问框架而来的轻量级数据开发框架...,主要特点是具有iBatis特点的SQL-MAP功能和框架独特的实体对象查询语言--OQL,下面我们使用OQL来构造一个复杂的实体查询。...首先定义两个实体类:用户类和订单类,可以使用框架提供的实体类生成器生成,下面是详细代码: /*   本类由PWMIS 实体类生成工具(Ver 4.1)自动生成  http://www.pwmis.com... IN ( SELECT UID  FROM Table_Order    Where OrderDate >= @CP1     ) OK,到此为止,我们可以使用我们的OQL查询出真正的实体集合了:...PDF.NET的宗旨就是为了最大化精简你的数据开发,有兴趣请看我的博客其它文章或者到官网:http://www.pwmis.com/sqlmap

    1.7K50

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

    通常情况下我们的ORM框架都是将单表或者视图映射成一个实体类,有时候也会将存储过程映射成实体类,如果处于系统移植性的考虑,你不想写存储过程,那这些复杂的SQL查询怎么映射成实体类?...我们使用PDF.NET(PWMIS数据开发框架)来实例讲解一下这个过程。...1,首先下载并安装一个“PDF.NET集成开发环境”,详细内容请参见《PDF.NET数据开发框架之集成开发工具Ver 4.1发布》,下面是该工具运行的界面: 2,在“数据连接”选项卡上,选择或创建一个连接分组...除了可以通过本文说的方式将SQL语句映射到实体类,还可以通过PDF.NET内置的SQL-MAP技术来实现实体类映射,就像iBaits那样,但比iBaits简单很多,详细内容,请参看: PDF.NET数据开发框架...之SQL-MAP使用存储过程 注:本文所说的自定义查询在PDF.NET3.5以后方可以支持,实例代码需要在PDF.NET 4.1以上支持,PDF.NET本身仅需要.net 2.0支持,框架的最新版本没有公开发布

    2.5K80

    03-EF Core笔记之查询数据

    显式加载:表示稍后从数据库中显式加载关联数据 延迟加载:表示在访问关联数据时,再从数据库中加载关联数据 预先加载 使用Include方法指定要包含在查询结果中的关联数据。...) .ThenInclude(owner => owner.Photo) .ToList(); } 如果更改查询,从而使其不再返回查询以之为开头的实体类型的实例,...,如果我们不需要跟踪查询返回的实体,则可以通过AsNoTracking方法禁用跟踪。...在执行查询时,EF Core会检查我们的sql语句是否支持拼接,如果支持的情况下,则会将linq过滤语句拼接为sql一并发送到数据库进行查询。 跟踪 原始SQL中的跟踪与Linq查询的跟踪方式一致。...关联数据 原始SQL中查询关联数据的方式与Linq查询的关联方式一致。 全局筛选器 全局筛选器对于软删除和多租户非常有用。

    2.5K20

    【公开课】ABP CORE 框架入门视频教程《电话薄》基于 Asp.NET Core2.0 EF Core

    ABP框架简介 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称。...ASP.NET Boilerplate是一个用最佳实践和流行技术开发现代WEB应用程序的新起点,它旨在成为一个通用的WEB应用程序框架和项目模板。...所以你可以放心大胆的使用ABP框架在实际的项目中。 正文 我个人未来的项目均会用.NET CORE 为核心技术,也是今年的目标。...使用.NET CORE 并不难,因为它.Net Framework的大部分API都是类似的。大家要有这个信心 本次录制的是一个公开课视频,使用的框架是ABP Core的3.4版本。...污~ 课程内容 ABP模板项目的生成 ABP框架分层项目简介 实体信息的创建 使用codefirst生成数据库 在Application层中实现Person的有关方法(一)-MPA版本 在Application

    1.6K40

    JPA实体类中的注解

    @Entity   标注于实体类上,通常和@Table是结合使用的,代表是该类是实体类 @Table   标注于实体类上,表示该类映射到数据库中的表,没有指定名称的话就表示与数据库中表名为该类的简单类名的表名相对应...@Id @Id设置对象表示符,标识的实体类的属性映射对应表中的主键 @GeneratedValue 设置标识符的生成策略,常与@Id一起使用  参数:strategy指定具体的生成策略  方式一:@...通常ORM框架可以根据属性类型自动判断数据库中字段的类型,但是对于Date类型仍无法确定数据库中字段类型究竟是DATE,TIME还是TIMESTAMP。...该属性通常不必指定,ORM框架根据属性类型自动判断targetEntity。 @OneToMany 描述一个一对多的关联,该属性应该为集体类型,在数据库中并没有实际字段。 ....多对多关联上是两个一对多关联,但是在ManyToMany描述中,中间表是由ORM框架自动处理  可选  targetEntity:表示多对多关联的另一个实体类的全名,例如:package.Book.class

    3.9K70

    .Net 从零开始构建一个框架之基本实体结构与基本仓储构建

    本系列文章将介绍如何在.Net框架下,从零开始搭建一个完成CRUD的Framework,该Framework将具备以下功能,基本实体结构(基于DDD)、基本仓储结构、模块加载系统、工作单元、事件总线(EventBus...,持久化对象和非持久化对象.本文主要讨论的是持久化对象,即需要写入到数据库或者其他数据容器中的对象,也就是实体(当然这里不是所谓的实体,而是通过OOP技术构建出来的一个实体结构,这个结构需要满足日常开发中绝大多数的业务需求...,存在一些共有方法,比如需要编写更加语义化的ToString方法,所以当不同类型需要共同的实现的时候,这个时候就需要一层抽象,来处理这层关系,所以就有了如下结构: [Serializable] 当然这个结构中可以有任何的共有方法...接着,基本实体就出现了,这里我分为两类,一类以int为主键,一类已Guid主键,为别写道两个类中,如下代码: /// /// 以int为主键的实体类型 ///...,当然这里你可以随意的扩展,比如构建各种各样的默认的实体类,如主键为string的只具有修改和删除的实体类.可以根据业务的实体特性来动态的扩展.也可以向所有的抽象实体类中添加任意的抽象属性或者方法.比如给

    76530

    选择块参照中嵌套的实体

    在利用ObjectARX进行CAD二次开发时,如何选择块参照中嵌套的实体,并进行进行下一步操作?这个问题的难点是:如何判断用户选中的实体到底是块参照里面的非嵌套对象实体?...还是块参照中嵌套的块参照的实体?本文利用全局函数acedNEnsSelP解决了这个问题,并可实现:如果用户选择块参照中嵌套的实体,直接视为用户选择了这个嵌套的块参照,效果如图。...一、全局函数acedNEntSelP介绍 为了选中块参照中的实体,ObjectARX提供了一个接口: int acedNEntSelP( const ACHAR * str, ads_name...ptres, int pickflag, ads_matrix xformres, struct resbuf ** refstkres ); const ACHAR * str:在选择块参照中实体时的提示语...ads_matrix xformres:该4×4变换矩阵可以将实体的任意ECS坐标转换为WCS坐标。如果选择的实体不是嵌套实体,该值设为单位矩阵。

    26531
    领券