收藏 分享(赏)

ORM框架VBC .Net实体代码生成工具(EntitysCodeGenerate)使用.doc

上传人:dreamzhangning 文档编号:4407199 上传时间:2018-12-27 格式:DOC 页数:29 大小:367KB
下载 相关 举报
ORM框架VBC .Net实体代码生成工具(EntitysCodeGenerate)使用.doc_第1页
第1页 / 共29页
ORM框架VBC .Net实体代码生成工具(EntitysCodeGenerate)使用.doc_第2页
第2页 / 共29页
ORM框架VBC .Net实体代码生成工具(EntitysCodeGenerate)使用.doc_第3页
第3页 / 共29页
ORM框架VBC .Net实体代码生成工具(EntitysCodeGenerate)使用.doc_第4页
第4页 / 共29页
ORM框架VBC .Net实体代码生成工具(EntitysCodeGenerate)使用.doc_第5页
第5页 / 共29页
点击查看更多>>
资源描述

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

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

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

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

5、e) 为 ORM 提供对象持久、简单对象查询、事务处理等功能。数据持久包括一些对象的Insert、 Update、Save、Delete 、Selec t 等功能,简单对象查询则提供一些基于对象的简单对象查询 GetEntity 及构造函数获取对象信息和实体集等。该工具是基于 VS.NET 2005 的开发的应用程序,职责是从数 据库中提取数据模型信息并生成实体类代码,帮助开发人员快速映射到关系数据库中的业务数据模型,最优化快速开发。目前直接提供从Oracle、SqlSe rver、Acces s、MySQL、Sybase、SQLite、DB2、PostgreSQL 、DM(达梦) 及支持 O

6、leDb 连接 的数据库和Custom(自定义)类型的数据库中生成VB/C#.Net 代码的支持,可以生成实体和实体集的相关代码,并自动提取数据库表和字段的注释说明和对应的数据类型等。另外所生成的代码文件只需修改数据库连接,即可用于目前市场上支持ADO.NET 的各 种类型的数 据库,如Oracle、SqlServer、MySQL、Access、Sybase、SQLit e、Excel、DB2 、PostgreSQL、Informix、Firebird 、MaxDB、DM(达梦)和 OleDb、ODBC 连接类型的数据库等。所生成代码文件的类关系图如下所示:工具 3.x 版本之后的实体层代码有

7、个基类(BaseE ntity),基类里其实也正是你项目的数据连接的配置位置,该工具实际应用时的配置其实也就在这里,默认为生成代码时所填写的数据库连接信息,并可手工扩展修改(如从 config 配置文件读取、实现对用户数据库连接信息的加密/解密等;大多数时候 我们只需在GetConnectionString()修改数据连 接字符串即可):public class BaseEntitypublic static string GetConnectionString()return “User ID=scott;Password=tiger;Data Source= oracle9“;/数据库连接

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

9、、查等操作。以数据库 Oracle的为例介绍 ,我们需要定义下层各种 数据库操作的公共组件:namespace System.Databasepublic class DbCore : IDisposablepublic int ExecuteNonQuery(DBCommandWrapper command)public DataSet ExecuteDataSet(DBCommandWrapper command)再定义数据库操作类及数据库的基类等,实现各种数据库类型的操作。public abstract class DBCommandWrapper internal abstract c

10、lass Database然后实现各种数据库的操作类,以 Oracle 为例internal class OracleDatabase : Databasepublic class OracleCommandWrapper : DBCommandWrapper最后在生成的实体类及基类文件中生成相应的数据库Insert,Update ,Delete , GetEntity,Save 等操作和类型映射代码如下所示:public int Insert()ORMap ormap = new ORMap(this);DEPT entity = new DEPT();return ormap.Insert

11、(entity);public static System.Data.DbType GetDBTypeByFullName(string strTypeFullName)switch (strTypeFullName)case “System.Byte“:return System.Data.DbType.Byte;case “System.Boolean“:return System.Data.DbType.Boolean;在生成代码的同时,工具自动添加实体类的属性标示及字段注释说明等如下所示:Serializable(),Description(“Primary:DEPTNO“)publi

12、c class DEPT:BaseEntity/ / 主键 DEPTNO/ DataObjectField(true)public int DEPTNOset _deptno=value;getreturn _deptno;/ / DNAME/ DataObjectField(false)public string DNAMEset _dname=value;getreturn _dname;实体中的 summary 中的注释 自动将数据中表及字段的注释说明提取到这里,方便程序员在代码编写及维护中交流使用,理解其所对应的业务含义。示例是以 Oracle数据库自带的示例库为 例介绍的,数据库自带

13、 的实例库 scott/tiger表注释为空,注释则以字段名代替。在这里可这样理解一张表对应一个实体类,表中的一条记录对应类的一个实例。实体定义完成后,我们需要根据实体类中绑定的属性构造出运行期间需要的SQL 语句,收集实体类定义中的数据结构描述,再定义一个 类来说明实体在运行期间所引用到的所有关于数据持久的信息,包括关键字字段,一般字段等等。同时需要一个字段的元数据字段在数据库中的名称,大小,是否可为空,列类型等信息。这些条件具备后,再定义解析类,负责转换数据的程序类型到数据库字段类型,并且构造出Insert,Updat e,Delete ,Select ,Save 等操作所需要的 SQL

14、语句,再去调用数据操作公有接口(DbCor e,支持自定义SQL 语句、存储过程和事务处理等),即可实现。同时数据操作公有接口System.Database.DbCore 结合实体类可将简单和复杂及事 务的操作更为方便的实现,下文着重介绍在实际中的使用。数据库操作默认以实体对应表的主键为准,当然也可以指定条件;并引入保存操作,即将增加和更新合并为一个保存操作,由实体对象本身自己根据主键或指定条件判断是增加还是更新操作。2.2 在开发中的实际应用VB/C#.Net 实体代码生成工具(EntitysCodeGene rate)安装后,在生成对应的实体代码后都会有个“相关配置”文件夹,里面有“配置说

15、明”文档和相关文件,实际使用时只须按“配置说明”文档操作即可。使用该工具开发的项目,可以做到很好的切换到异构数据库,且只需变动数据库连接接口即可(即只须修改GetDatabaseType()/GetConnectionString()。同时提供了 ORMaping.dll(1.0 版本引用),System.Database.dll(2.0/3.0/3.x/4.x 版本引用)安装目录下有相应的chm 格式帮助文档,是对这两个 dll 单独使用的说明,支持自定义的数据库访问,并可结合生成的实体操作数据库,提供良好的事务处理等。其中 ORMaping.dll 支持Oracle ;System.Dat

16、abase.dll 默认支持 Oracle,并可用于各种类型的数据库访问,如SqlServer、MySQL、Sybase、DB2、SQLite、Postg reSQL、Infor mix、Firebird、MaxDB、DM(达梦)、OleDb、Odbc 等,对没有直接提供的数据库类型可使用OleDb 或 Odbc 连接。工具所生成 的代码和提供的文件,都是可选配 的,可单独使用也可配置使用。实体代码的生成界面比较简单,如下所示:这里,只须选择数据库类型、输入正确的数据库连接字符串(Custom(自定义)的数据库类型填写正确自定义程序集信息)、代码文件的输出目录和代码命名空间即可。实体数据类型以

17、” 数据类型映射文件” 为准,工具提供了系统默认的类型映射,若有自定义的数据类型,在”数据类型映射文件”里修改,可配置到数据类型的精确刻度。数据类型初始值在” 数据类型初始值文件”里修改,没有配置的取.Net 默认值。若修改过程 中想恢复默认的配置,只须点击”生成” 按钮即可(注意不同语言的类型定义可能有所差异,注意区分。如:C#的 byte,在 VB中的定义为 byte()。准备工作做好后,单击”生成代码”按钮即可(若不想全部生成,单击”选择生成 ”按钮 )。生成成功之后按提示生成的配置说明文档,将实体代码文件和基类文件拷贝到指定目录,并按生成代码文件所在”相关配置”目录下配置说明文档,添加

18、对应 dll 文件的引用即可。操作简单这里就不在此赘述,下面 C#.Net 语言为例开始介 绍实体对象的数据库操作的工作,VB.Net 同理对比使用。先介绍单个实体类的数据库操作的工作:2.2.1 常用单实体对象数据库操作这里还是以Oracle 附带库 DEPT 为例来做说明,首先做对象的声明DEPT entity = new DEPT();下面以该对象来做阐述。1、获取一个实体对象实体的操作默认以主键为准,对单个实体信息的获取可简单如下实现:entity.DEPTNO = 50;entity = entity.GetEntity();返回主键字段 DEPTNO=50 的对象,若数据库中没有对

19、应的记录则返回null。DEPT 表的主键字段是 DEPTNO,同时对联合主键也是支持的,下文同此;GetEntity 同时提供其它指定条件的重载,也可以使用GetEntityByEntityCondition,当指定条件有多个记录符合时只返回首条记录;返回多条记录可使用 GetDataTable 方法。在 3.3 版本之后也可通过多个构造函数来获取单个实体对象的信息等:DEPT entity = new DEPT(50); /通过主键字段条件获取实体对象DEPT entity = new DEPT(“DEPTNO“, 50); /指定唯一字段条件获取实体对象DEPT entity = new

20、 DEPT(new string “DEPTNO“ , new object 50 );另外,可通过实体集多个构造函数获取多实体对象信息的查询( 实体集对象查询)等,如:DEPTS entity = new DEPTS(true); /获取所有信息EMPS entitys = new EMPS (“DEPTNO“, 50) /获取 DEPTNO=50所有雇员信息EMPS entitys1 = new EMPS(new string “DEPTNO“ , new object 50 );DataTable dtbl = entitys.ToDataTable();/将获取的实体集对象信息转换到数

21、据表 DataTable2、新增一个实体对象新增一个对象代码可如下所示:entity.DEPTNO = 51;entity.DNAME = “DNAME1”;entity.LOC = “LOC1”;entity.Insert();同时 Insert 提供 多种相应的 重载和 InsertAll 方法; Insert 和 InsertAll 区别是:Insert 在插入记录时会比较对象初始的字段值,将与初始值 不同的值插入,其余的以表字段的默认方式处理;InsertAll 则是插入全部字段,即使是对象的初始值没有改变也会插入。3、更新一个实体对象更新一个对象代码可如下所示:entity.DEPT

22、NO = 51;entity.DNAME = “DNAME2”;entity.LOC = “LOC2”;entity.Update();Update 也提供多种相应的重载和 UpdateAll 方法;Update 和 UpdateAll 区别是:Update 在更新记录时会比较对象初始的字段值,将与初始值不同的值进行更新,其余的表字段不更新;UpdateAll 则是更新全部字段,即使是对象的初始值没有改变也会将对象的初始值更新到表里。可根据情况选择使用。4、保存一个实体对象保存是该工具新增的功能,即将新增和更新合并到一个保存功能里,ORM 会根据主键约束自动解析是新增还是更新,保存一个对象的代

23、码可如下所示:entity.DEPTNO = 51;entity.DNAME = “DNAME3”;entity.LOC = “LOC3”;entity.Save();保存操作也是默认以主键为准,对多个联合主键也是支持的,不带参数的保存默认是按主键判断有对应的记录就更新,没有就插入新记录。同时 Save 提供多种重载和 SaveAll、SaveByEntityCondition 方法,Save 和SaveAll 区别同新增和更新。5、删除一个实体对象删除可如下代码所示:entity.DEPTNO = 51;entity.Delete();删除操作也是默认以主键为准,对多个联合主键也支持,同时也

24、提供多种指定条件的重载方法。最后附加说明实体对象的增删改保存操作都会返回一个 int值,该值返回表中记录受影响的行数。从这些代码可以明显的看到,这里常用的数据增、删、改、查操作只需很简单几句即可实现,少写了很多代码,是不是很好!6、取得实体映射表数值字段的最大 ID+1代码可如下:int intID = entity.GetInt32MaxID();这里获取实体对象对应表字段默认第一个主键的最大值 ID+1,类型为整型,同时提供 GetInt?MaxID多种重载,即有整型和 长整型及指定字段等。本节介绍的都是单表无事务的操作,下节介绍多表及事务处理的操作。除此之外,还提供一系列 CRUD的扩展

25、方法,如:InsertEx / UpdateEx / SaveEx / DelInsert / DelInsertEx和 实体集对象的批量操作,如:entitys.ToDataTable / Save / SaveAll / SaveEx / Delete / DelInsert / DelInsertEx等;详见示例代码、生成代码及相关帮助文档。其中实体集对象的批量操作自动启用事务处理,操作成功统一提交,发生异常统一回滚。2.2.2 多个实体对象及事务处理并结合 System.Database 的工作这里简略介绍实体对象结合 System.Database.DbCore 及事务处理是如何工作

26、的,先看以下代码(可参见安装示例代码 System.Database.Demo):Entitys.Common.LC_WORKTYPE entity = new Entitys.Common.LC_WORKTYPE();entity.ID = 1;entity.TYPENAME = “TYPENAME“;string strConnection = “Password=newaqfx;User ID= newaqfx;Data Source=85“;DbCore dbCore = new DbCore(DatabaseType.Oracle, strConnection);dbCore.Ope

27、n();dbCore.BeginTransaction();dbCore.Save(new Entitys.Common.LC_WORKTYPE(), entity);entity.DESCRIPTION = “类型描述“;dbCore.Save(new Entitys.Common.LC_WORKTYPE(), entity);entity.TYPENAME = “作业类型“;dbCore.Save(new Entitys.Common.LC_WORKTYPE(), entity);DataSet dst = dbCore.ExecuteDataSet(“select * from lc_w

28、orktype“);entity.ID = 1;DataTable dt = dbCore.GetDataTableByEntityKey(entity);int intRecord = dbCore.Delete(entity);dt = dbCore.GetDataTableByEntityKey(entity);dbCore.CommitTransaction();dbCore.Close();这里使用另外一个实体LC_WORKTYPE(映射到 XX系统的 “作业类型“这张表),BeginTransaction()为开始事务的标志,Commi tTransaction()为提交当前事务,

29、还一个是 RollbackTransaction()表示回滚当前事务,放弃当前事 务下所有数据的更改。这样在事务开始和提交或回滚之间可以进行多个实体的操作,并将结果最终一起提交或回滚撤销。这里 Save 有两个参数第一个是实体对象的初始类用于比较实体的初始值,第二个是要保存的对象,该方法依据主键自动判断表数据是更新还是插入;同时与 Save 类似的方法有 SaveAll保存全部字段,同时也有重载及Insert、InsertAll、Update、UpdaAll 、Delete 、IsExi tByEntityKey、Exist s、Get?MaxId等方法,均可相互结合使用,方法都有详尽的说明及

30、示例代码。该方法执行过程中可单步跟踪,查看该事务下每步命令执行后对应的数据集信息。下面再看以Oracle 自带的 scott 库为例一段代码 Delete、Inser t、Update 并结合事务使用的代码:DbCore dbCore = null;tryEMP entity1 = new EMP();DataSet dst = new DataSet();entity1.EMPNO = 7369; /设置主键 EMPNO为entity1 = entity1.GetEntity(); /取得主键 EMPNO为实体对象信息/“User ID=scott;Password=tiger;Data S

31、ource=85“;dbCore = new DbCore(Entitys.Common.BaseEntity.GetConnectionString();dbCore.Open();dbCore.BeginTransaction();/选择当前事务下的所有雇员 EMP的信息dst = dbCore.SelectAll().From(entity1).ExecuteDataSet();dbCore.Delete(entity1);/删除主键 EMPNO为7369 的记录dst = dbCore.SelectAll().From(entity1).ExecuteDataSet();/查看当前事务

32、下记录,当前删除记录将不在此显示dbCore.Insert(new EMP(), entity1);/插入刚才删除主键 EMPNO为 7369的记录=dbCore.Save(new EMP(), entity1);dst = dbCore.SelectAll().From(entity1).ExecuteDataSet();/查看当前事务下记录,可见刚刚插入的新记录entity1.SAL = entity1.SAL + 100;/薪水加 100dbCore.Update(new EMP(), entity1);/更新=dbCore.Save(new EMP(), entity1);dst =

33、dbCore.SelectAll().From(entity1).ExecuteDataSet();/查看当前事务下记录,对应薪水 SAL已更新entity1.SAL = entity1.SAL - 100;/ 薪水减 100dbCore.Update(new EMP(), entity1);/更新=dbCore.Save(new EMP(), entity1);dst = dbCore.SelectAll().From(entity1).ExecuteDataSet();/查看当前事务下记录,对应薪水 SAL已更新dbCore.CommitTransaction();dbCore.Close

34、();catch (Exception ex)if (dbCore != null)if (dbCore.IsTransaction)dbCore.RollbackTransaction();/如果已经开始事务,则回滚事务dbCore.Close();上面的 Insert、Updat e 方法都可以 Save方法来取代,Save 方法会自动判断是Update 还是Insert,这里只是用 来展示之用。诚然 ORM并不是万能的,当遇到特别复杂的数据处理及海量数据处理、性能优化和弥补设计的不足时,还应归结到SQL 语句或存储过程来实现才是好的选择。实际项目中仍然会有海量复杂的数据处理或复杂子查询和

35、不同类型数据库、SQL语句优化和存储过程等,工具组件 System.Database.DbCore 提供了良好的解决方案,很好的解决了项目中 10%-20%的那部分功能。该组件支持目前市场上ADO.NET 支持的各种类型的数据库,可执行自定义编写的 SQL 语句和存储过程等,这样可针对复杂功能特殊处理及对项目瓶颈问题作性能优化操作等。System.Database.DbCore 可直接用于Oracle、SqlServer 、MySql、Sybase 、DB2 、SQLite 、 PostgreSQL、Informix、Fireb ird、 MaxDB、Acces s、DM( 达梦) 和支持 O

36、leDb、Odbc 连接类型的数据库,实例代码分别如下:DbCore dbCore = new DbCore(DatabaseType.Oracle, “OracleConnectionString”);DbCore dbCore = new DbCore(DatabaseType.SqlServer, “SqlServerConnectionString”);DbCore dbCore = new DbCore(DatabaseType.MySql, “MySqlConnectionString”);DbCore dbCore = new DbCore(DatabaseType.Sybase

37、, “SybaseConnectionString”);DbCore dbCore = new DbCore(DatabaseType.DB2, “DB2ConnectionString”);DbCore dbCore = new DbCore(DatabaseType.SQLite, “SQLiteConnectionString”);DbCore dbCore = new DbCore(DatabaseType.PostgreSQL, “PostgreSQLConnectionString”);DbCore dbCore = new DbCore(DatabaseType.Informix

38、, “InformixConnectionString”);DbCore dbCore = new DbCore(DatabaseType.Firebird, “FirebirdConnectionString”);DbCore dbCore = new DbCore(DatabaseType.MaxDB, “MaxDBConnectionString”);DbCore dbCore = new DbCore(DatabaseType.Access, “AccessConnectionString”);DbCore dbCore = new DbCore(DatabaseType.Dm, “D

39、mConnectionString”);DbCore dbCore = new DbCore(DatabaseType.OleDb, “OleDbConnectionString”);DbCore dbCore = new DbCore(DatabaseType.Odbc, “OdbcConnectionString”);下面看一段适合 Oracle 和 SqlServer 访问的通用代码:DbCore dbCore = PublicClass.GetNewDbCore();string strParaToken = dbCore.GetCurrentParameterToken; /对应数据

40、库的参数前导符string strSql = “INSERT INTO dept (deptno, dname, loc) VALUES (“ + strParaToken + “deptno, “+ strParaToken + “dname, “ + strParaToken + “loc)“;dbCore.Open(); /打开数据库连接dbCore.BeginTransaction(); /开始事务DBCommandWrapper cmd = dbCore.GetSqlStringCommandWrapper(strSql);/cmd.AddParameter();/为命令增加一个参数

41、实例cmd.AddInParameter(strParaToken + “deptno“, DbType.Int32, 99);cmd.AddInParameter(strParaToken + “dname“, DbType.String, “部门名称“);cmd.AddInParameter(strParaToken + “loc“, DbType.AnsiString, “locTest“);int intMaxDeptId = dbCore.GetInt32MaxId(“dept“, “deptno“);/当前表的 deptno最大值dbCore.ExecuteNonQuery(cmd

42、);intMaxDeptId = dbCore.GetInt32MaxId(“dept“, “deptno“);/插入数据 deptno=99之后当前表的deptno最大值strSql = “DELETE dept WHERE deptno = “ + strParaToken + “deptno“;DBCommandWrapper cmd1 = dbCore.GetSqlStringCommandWrapper(strSql);cmd1.AddInParameter(strParaToken + “deptno“, DbType.Int32, 99);dbCore.ExecuteNonQue

43、ry(cmd1);intMaxDeptId = dbCore.GetInt32MaxId(“dept“, “deptno“);/删除数据 deptno=99之后当前表的deptno最大值dbCore.RollbackTransaction();/回滚撤销事务。等于该方法什么都没做,只是演示作用intMaxDeptId = dbCore.GetInt32MaxId(“dept“, “deptno“);dbCore.Close();/关闭数据库连接其中第一句的 PublicClass.GetNewDbCore()方法体代码可以是new DbCore(DatabaseType.Oracle,“Ora

44、cleConnectionString”)也可以是new DbCore(DatabaseType.SqlServer, “SqlServerConnectionString”),当new的是 Oracle时即表示操作访问的是 Oracle数据库,当 new的是 SqlServer即表示操作访问的是 SqlServer数据库。dbCore.GetCurrentParameterToken即是获取对应数据库连接参数的前导符(如:Oracle 是“:”,SQL Server 是“”等),这里也可以结合使用 dbCore.StandardSqlWithParameters方法对当前带参数的 SQL语句

45、进行标准化通用处理,即所写 SQL可以用于如MySql/Access数据库等。这里的数据库操作同样也是可以同实体对象一块协同工作。dbCore.GetSqlStringCommandWrapper()创建一个 SQL语句的命令,dbCore.GetStoredProcCommandWrapper()创建一个执行存储过程的命令,可根据项目自身实际需要选择使用。对专有数据库命令也可以转化为指定数据库命令来使用,这样可针对该数据库特性使用更多的方法,如 Oracle、SqlServer 的命令转化可像下列代码来转化:OracleCommandWrapper cmd = dbCore.GetSqlSt

46、ringCommandWrapper(strSql) asOracleCommandWrapper;SqlCommandWrapper cmd = dbCore.GetSqlStringCommandWrapper(strSql) as SqlCommandWrapper;这里顺便说明一下当程序执行出现异常时可使用 dbCore.Close()来关闭当前打开的数据库连接,如下代码所示:catch (Exception ex)if (dbCore != null)if (dbCore.IsTransaction)dbCore.RollbackTransaction();/如果已经开始事务,则回滚

47、事务dbCore.Close();MessageBox.Show(ex.Message);最后再说一个System.Database.DbCoreConnectLimit.AllDBMaxConnectionCount,可以设置数据库可打开的最大连接数目,默认不受限制。2.2.3 数据查询及通用 DML操作如一般的关系型数据库所具有的查询功能一样,EntitysCodeGenerate 也有着非常丰富的查询功能,如对象查询、数据集查询、函数查询、条件查询、排序查询、分组等。这里对数据查询做简单介绍。EntitysCodeGenerate 提供ENTITYColumn类帮助 System.Dat

48、abase.DbCore.Select从数据源查询数据,Select通过 ENTITYColumn实体属性,构造查询语句。Select 在运行时定义查询筛选语句,并执行返回结果数据集。1、 常用实体对象查询常用实体对象查询,见上节常用实体对象数据库操作一节的第一段所述,这里就不在赘述。2、 ORM 结构化查询这里先介绍表实体原描述信息类 ENTITYColumn,这里”ENTITY”为表实体类对应的占位符,其类下有实体所对应的表的表名和表字段的公共静态只读信息。其中的 TableName为每个该类的对应表名,各属性字段为表名、字段名、字段对应类型的完全限定名,以键盘不能直接输入的偏僻符号 为分

49、割拼接而成。ORM结构化查询时可使用该类。2.1、Select 查询System.Database.DbCore类提供 Select方法及其相应的重载,以 SqlServer自带的 pubs库为例,可见如下代码:DataSet dst = new DataSet();DbCore dbCore = new DbCore(DatabaseType.SqlServer, “Server=(local);User id=sa;Pwd=sa;Database=pubs“);DataSet dst = dbCore.SelectAll().From(“sales“).ExecuteDataSet();DataSet dst = dbCore.SelectAll().From(SALESColumn.TableName).ExecuteDataSet();DataSet dst = dbCore.Select(SALE

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 网络科技 > 软件工程

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报