网站内容注意事项,买域名和服务器一般要多少钱,广告策划书包括什么内容,房地产新闻发布会DAO Data Access Object#xff0c;数据访问对象 DAO是一个软件设计的指导原则#xff0c;在核心J2EE模式中是这样介绍DAO模式的#xff1a;为了建立一个健壮的J2EE应用#xff0c;应该将所有对数据源的访问操作抽象封装在一个公共API中。用程序设计的语言来说#xff0c;… DAO Data Access Object数据访问对象 DAO是一个软件设计的指导原则在核心J2EE模式中是这样介绍DAO模式的为了建立一个健壮的J2EE应用应该将所有对数据源的访问操作抽象封装在一个公共API中。用程序设计的语言来说就是建立一个接口接口中定义了此应用程序中将会用到的所有事务方法。在这个应用程序中当需要和数据源进行交互的时候则使用这个接口并且编写一个单独的类来实现这个接口在逻辑上对应这个特定的数据存储。 简单的说DAO就是对数据库中数据的增删改查等操作封装在专门的类里面在业务逻辑层中如果要访问数据的时候直接调用该DAO类包括了如何访问数据库和数据的增删改查等等代码就可以返回数据而不需要再在业务逻辑层中写这些代码。 ORM概念 面向对象的开发方法是当今企业级应用开发环境中的主流开发方法关系数据库是企业级应用环境中永久存放数据的主流数据存储系统。 在业务逻辑层和用户界面层中我们是面向对象的。当对象信息发生变化的时候我们需要把对象的信息保存在关系数据库中。 当你开发一个应用程序的时候(不使用O/R Mapping),你可能会写不少数据访问层的代码用来从数据库保存删除读取对象信息等等。你在DAL中写了很多的方法来读取对象数据改变状态对象等等任务。而这些代码写起来总是重复的。 面向对象是从软件工程基本原则(如耦合、聚合、封装)的基础上发展起来的而关系数据库则是从数学理论发展而来的两套理论存在显著的区别。为了解决这个不匹配的现象对象-关系映射Object/Relation Mapping简称ORM技术应运而生。 对象和关系数据是业务实体的两种表现形式业务实体在内存中表现为对象在数据库中表现为关系数据。内存中的对象之间存在关联和继承关系而在数据库中关系数据无法直接表达多对多关联和继承关系。因此对象-关系映射(ORM)系统一般以中间件的形式存在主要实现程序对象到关系数据库数据的映射。 对象关系映射ORM提供了概念性的、易于理解的模型化数据的方法。ORM方法论基于三个核心原则 简单以最基本的形式建模数据。传达性数据库结构被任何人都能理解的语言文档化。精确性基于数据模型创建正确标准化了的结构。典型地建模者通过收集来自那些熟悉应用程序但不熟练的数据建模者的人的信息开发信息模型。建模者必须能够用非技术企业专家可以理解的术语在概念层次上与数据结构进行通讯。建模者也必须能以简单的单元分析信息对样本数据进行处理。ORM专门被设计为改进这种联系。 ORM不是DAO这样的指导原则它往往依赖一个具体的库实现。一般的ORM包括以下四部分 一个对持久类对象进行CRUD操作的API一个语言或API用来规定与类和类属性相关的查询一个规定mapping metadata的工具一种技术可以让ORM的实现同事务对象一起进行dirty checking, lazy association fetching以及其他的优化操作。ORM 类型 1. ActiveRecord 软件工程中Active Record简称AR模式是软件里的一种架构性模式主要概念是关系型数据库中的数据在内存中以对象的形式存储。由Martin Fowler在其2003年初版的书籍《Patterns of Enterprise Application Architecture》命名。遵循该模式的对象接口一般包括如Insert, Update, 和 Delete这样的函数以及对应于底层数据库表字段的相关属性。 AR模式是一种访问数据库数据的方式。数据表或视图被映射成一个类。每个对象实例则对应于表的一条记录。对象被创建后通过save就可以向表中新添一行记录。当对象被更新时表中相应记录也被更新。这个包裹类通过属性或方法的形式实现访问表或视图中的每一个字段。 该模式主要被对象持久化工具采用用于对象关系映射 (ORM). 典型的外键关系会以合适的对象实例属性的形式暴露访问。 2. Row Data Gateway Row Data Gateway模式中每个对象也封装了数据库记录的状态和持久化到数据库的访问方法; 这两个有时候很难区分. 细微的区别在于Row Data Gateway不封装任何业务逻辑; 3. TableGateway TableGateway是一种数据访问模式, 对每个表有一个类, 类的方法封装了对单个表的数据操作, 如CRUD; 方法的接受表字段的值作为参数; 比如说对表Person有Person DAO, 有以下方法: int Create(string name, bool isMale)
DataSet Find(int personId)
void Delete(int personId)
void Update(int personId, string name, bool isMale) 微软的很多代码示例中使用了此模式; ActiveRecord的区别在于ActiveRecord的对象中保持了记录的值, 是有状态的, 而TableGateway是没有状态的, 只是一系列数据库访问方法的集合; Table Module Table Module是一种领域逻辑模式, 一个类对应于数据库中的一个表; Table Module通常和Table Gateway合作, 前者负责基本的业务逻辑, 后者负责数据库访问, 以达到逻辑层和持久化层的隔离; 微软的实例代码经常使用这两者, 如对表Person, 通常会定义两个类, PersonBL和PersonDB, 在PersonBL中处理验证等逻辑, 并调用PersonDB访问数据库, 层间调用使用DataSet或自定义数据传输对象传输数据 在业务逻辑比较简单并且有和表的一一对应时, ActiveRecord相对来说更简单, 因为它在一个类中包括了业务逻辑对象和数据访问, 而且不需要数据传输对象, 减少了维护的工作量;和Table Module比较起来, ActiveRecord与数据库耦合更紧。 转载于:https://www.cnblogs.com/x3d/p/6250560.html