orm框架vbc .net实体代码生成工具(entityscodegenerate)使用

上传人:xins****2008 文档编号:113498290 上传时间:2019-11-08 格式:DOC 页数:28 大小:367KB
返回 下载 相关 举报
orm框架vbc .net实体代码生成工具(entityscodegenerate)使用_第1页
第1页 / 共28页
orm框架vbc .net实体代码生成工具(entityscodegenerate)使用_第2页
第2页 / 共28页
orm框架vbc .net实体代码生成工具(entityscodegenerate)使用_第3页
第3页 / 共28页
orm框架vbc .net实体代码生成工具(entityscodegenerate)使用_第4页
第4页 / 共28页
orm框架vbc .net实体代码生成工具(entityscodegenerate)使用_第5页
第5页 / 共28页
点击查看更多>>
资源描述

《orm框架vbc .net实体代码生成工具(entityscodegenerate)使用》由会员分享,可在线阅读,更多相关《orm框架vbc .net实体代码生成工具(entityscodegenerate)使用(28页珍藏版)》请在金锄头文库上搜索。

1、1引言目前大多数项目或产品都使用关系型数据库实现业务数据的存储,这样在开发过程中,常常有一些业务逻辑需要直接用写SQL语句实现,但这样开发的结果是:遍地布满SQL语句。这些藕合较高的SQL语句给系统的改造和升级带来很多无法预计的障碍。或者说可以使用服务端数据库存储子程序实现,但只是将这种耦合搬迁到后端,问题依然没有根本解决,服务端驻留过多的存储子程序也消耗着服务器的性能并给多人合作维护和更新部署带来许多障碍。为了提高项目的灵活性,特别是快速开发,ORM是一个不错的选择。举个简单的例子:在使用ORM的系统中,当数据库模型改变时,不再需要理会逻辑代码和SQL语句中涉及到该模型的所有改动,只需要将该

2、模型映射的对象稍作改动,甚至不做改动就可以满足要求。ORM的全称是Object Relational Mapping,即对象关系映射。它的实质就是将关系数据(库)中的业务数据用对象的形式表示出来,并通过面向对象(Object-Oriented)的方式将这些对象组织起来,实现系统业务逻辑的过程。在ORM过程中最重要的概念是映射(Mapping),通过这种映射可以使业务对象与数据库分离。从面向对象来说,数据库不应该和业务逻辑绑定到一起,ORM则起到这样的分离作用,使数据库层透明,开发人员真正的面向对象。下图简单说明了ORM在多层系统架构中的这个作用。图1ORM在多层系统架构中的作用当然ORM并非是

3、万能的,面对纷繁复杂的业务逻辑,当遇到特别复杂的数据处理及海量数据处理和弥补设计的不足时还应归结到SQL或存储过程来实现,但它却很好的体现了“80/20(或90/10)法则”(也被称为“帕累托法则”),也就是说:花比较少(10%-20%)的力气就可以解决大部分(80%-90%)的问题,这样通过利用ORM框架,我们就仅需要付出极少数时间和精力来解决剩下的少部分问题了,这无疑缩短了整个项目开发的周期。因此快速开发、面向对象和性能优化等必须灵活兼顾才好,这些该工具都提供了很好的解决方案,下文分别作一介绍。2内容2.1 ORM框架的实现:VB/C#.Net实体代码生成工具(EntitysCodeGen

4、erate)好的ORM框架工具不仅可以帮助我们很好的理解对象及对象的关系,而且工具本身会帮助我们维护这些关系,帮助我们记住字段属性业务含义并提供辅助的应用等。基于这个理念,我于多年的项目实践和业余时间设计研发了一个基于.NET的ORM工具VB/C#.Net实体代码生成工具(EntitysCodeGenerate),该工具运行于dotnetframework2.0框架上,适用性广,开发后的代码部署要求不高,在.Net更高版本上也可以很好的运行。VB/C#.Net实体代码生成工具(EntitysCodeGenerate)为ORM提供对象持久、简单对象查询、事务处理等功能。数据持久包括一些对象的In

5、sert、Update、Save、Delete、Select等功能,简单对象查询则提供一些基于对象的简单对象查询GetEntity及构造函数获取对象信息和实体集等。该工具是基于VS.NET 2005的开发的应用程序,职责是从数据库中提取数据模型信息并生成实体类代码,帮助开发人员快速映射到关系数据库中的业务数据模型,最优化快速开发。目前直接提供从Oracle、SqlServer、Access、MySQL、Sybase、SQLite、DB2、PostgreSQL、DM(达梦)及支持OleDb连接的数据库和Custom(自定义)类型的数据库中生成VB/C#.Net代码的支持,可以生成实体和实体集的相

6、关代码,并自动提取数据库表和字段的注释说明和对应的数据类型等。另外所生成的代码文件只需修改数据库连接,即可用于目前市场上支持ADO.NET的各种类型的数据库,如Oracle、SqlServer、MySQL、Access、Sybase、SQLite、Excel、DB2、PostgreSQL、Informix、Firebird、MaxDB、DM(达梦)和OleDb、ODBC连接类型的数据库等。所生成代码文件的类关系图如下所示:工具3.x版本之后的实体层代码有个基类(BaseEntity),基类里其实也正是你项目的数据连接的配置位置,该工具实际应用时的配置其实也就在这里,默认为生成代码时所填写的数据

7、库连接信息,并可手工扩展修改(如从config配置文件读取、实现对用户数据库连接信息的加密/解密等;大多数时候我们只需在GetConnectionString()修改数据连接字符串即可):publicclassBaseEntitypublicstaticstringGetConnectionString()returnUser ID=scott;Password=tiger;Data Source=oracle9;/数据库连接设置可修改从别处读取publicstaticDatabaseTypeGetDatabaseType()returnDatabaseType.Oracle;/数据库连接类型

8、设置也可修改从别处读取这里可设置该命名空间当前实体下的数据库连接类型及数据库连接字符串,当然也可以修改成从其它如配置文件中读取(以前的版本是放在全局设置DbConnectString这个类里面,这样的缺陷是当一个项目有多个数据库时将不好处理,而现在通过使用基类继承及命名空间划分则很容易解决)。在ORM实现的前期工作中,为了实现屏蔽各种数据库之间的操作差异,我们需要定义数据操作公有接口,封装基本的数据库增、删、改、查等操作。以数据库Oracle的为例介绍,我们需要定义下层各种数据库操作的公共组件:namespaceSystem.DatabasepublicclassDbCore:IDisposa

9、blepublicintExecuteNonQuery(DBCommandWrappercommand)publicDataSetExecuteDataSet(DBCommandWrappercommand)再定义数据库操作类及数据库的基类等,实现各种数据库类型的操作。publicabstractclassDBCommandWrapperinternalabstractclassDatabase然后实现各种数据库的操作类,以Oracle为例internalclassOracleDatabase:DatabasepublicclassOracleCommandWrapper:DBCommandW

10、rapper最后在生成的实体类及基类文件中生成相应的数据库Insert,Update,Delete,GetEntity,Save等操作和类型映射代码如下所示:publicintInsert()ORMapormap=newORMap(this);DEPT entity=newDEPT();returnormap.Insert(entity);publicstaticSystem.Data.DbTypeGetDBTypeByFullName(stringstrTypeFullName)switch(strTypeFullName)caseSystem.Byte:returnSystem.Data.

11、DbType.Byte;caseSystem.Boolean:returnSystem.Data.DbType.Boolean;在生成代码的同时,工具自动添加实体类的属性标示及字段注释说明等如下所示:Serializable(),Description(Primary:DEPTNO)publicclassDEPT:BaseEntity/主键DEPTNO/DataObjectField(true)publicintDEPTNOset _deptno=value;getreturn_deptno;/DNAME/DataObjectField(false)publicstringDNAMEset _

12、dname=value;getreturn_dname;实体中的summary中的注释自动将数据中表及字段的注释说明提取到这里,方便程序员在代码编写及维护中交流使用,理解其所对应的业务含义。示例是以Oracle数据库自带的示例库为例介绍的,数据库自带的实例库scott/tiger表注释为空,注释则以字段名代替。在这里可这样理解一张表对应一个实体类,表中的一条记录对应类的一个实例。实体定义完成后,我们需要根据实体类中绑定的属性构造出运行期间需要的SQL语句,收集实体类定义中的数据结构描述,再定义一个类来说明实体在运行期间所引用到的所有关于数据持久的信息,包括关键字字段,一般字段等等。同时需要一个字段的元数据字段在数据库中的

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 大杂烩/其它

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号