快速业务通道

Enterprise Library 2.0 -- Data Access Application Block

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-21

前面介绍了Enterprise Library 2.0中的Caching Application Block和Cryptography Application Block,今天我们来看一下Enterprise Library 2.0里对数据处理的部分--Data Access Application Block。它为我们开发者提供了对数据处理的大部分通用的方法。其内容包括:

1、使用DataReader返回多行数据

2、使用DataSet返回多行数据

3、返回一个输出型参数

4、返回一个单一值

5、事务处理

6、返回XML数据

7、使用DataSet来修改数据库

8、Enterprise Library 2.0 -- Data Access Application Block (补充)

...

看起来DataAccess Application Block很像是ADO.NET,确实如此,DataAccess Application Block 不是ADO.NET的替代品,它是对ADO.NET的补充。DataAccess Application Block的优点在于它可以使用相同的代码去访问不同类型的数据库,比如我们的应用程序从Sql Server上转到Oracle,那么使用DataAccess Application Block 可以让你不需要修改任何代码而达到上述功能,不过配置文件是当然要修改的。当然也不是在任何情况下都要用DataAccess Application Block,例如,当我们的代码是为了一种很特殊的数据库而编写的话,这时候应该选用ADO.NET。

首先我们来看一下DataAccess Application Block 是如何配置的(以Sql Server 2000为例)。

首先打开Enterprise Library提供的配置工具,选择File-->Open Application,选中我们项目种的Web.Config或App.Config文件:

Enterprise Library 2.0 -- Data Access Application Block

修改DataBase名称为我们需要连接的数据库名称:

Enterprise Library 2.0 -- Data Access Application Block

修改Server,指定数据库服务器名:

Enterprise Library 2.0 -- Data Access Application Block

再添加两个参数,分别是uid和pwd:

Enterprise Library 2.0 -- Data Access Application Block

最后点 File-->Save All,这样就完成了一个数据库的配置。生成的配置文件内容如下:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
 <configSections>
  <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=2.0.0.0, Culture=neutral, PublicKeyToken=null" />
 </configSections>
 <dataConfiguration defaultDatabase="Connection String" />
 <connectionStrings>
  <add name="Connection String" connectionString="Database=EnterpriseLibrary;Server=shy;Integrated Security=SSPI;uid=sa;pwd=;"
   providerName="System.Data.SqlClient" />
 </connectionStrings>
</configuration>
在其中的ConnectionStrings节里我们可以看到我们刚刚配置时输入的数据库信息。

下面我们重点来说一下DataAccess Application Block操作数据库的方法。

1、创建一个数据库实例DataBase

//创建一个默认的数据库实例
Database defaultdb = DatabaseFactory.CreateDatabase();
//创建一个名为Connection String的数据库实例
Database db = DatabaseFactory.CreateDatabase("Connection String");
//上面两种创建数据库实例的方法的数据库可以是任何类型的数据库,取决于Config文件中的配置信息
//下面的这种方面展示了创建一个SQL数据库的实例,需引用Microsoft.Practices.EnterpriseLibrary.Data.Sql程序集
SqlDatabase dbsql = DatabaseFactory.CreateDatabase("Connection String") as SqlDatabase;
//我们同样也可以不通过配置文件来创建数据库实例,如下
string connString = "server=.;database=EnterpriseLibrary;uid=sa;pwd=";
SqlDatabase nocofigdb = new SqlDatabase(connString);

2、创建DbCommand

DbCommand的

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号