Welcome

首页 / 软件开发 / .NET编程技术 / Enterprise Library2.0(1):Data Access Application Block学习

Enterprise Library2.0(1):Data Access Application Block学习2011-02-03 cnblogs terryleeData Access Application Block提供了通用的数据访问的功能,随着2.0版本的推出有了很大变化。

一.改进

在DAAB1.1里面我们知道Database方法返回或者创建一个DBCommandWrapper对象,而在DAAB2.0里面移除了DBCommandWrapper类,用ADO.NET2.0里面的DBCommand类代替实现类似的功能,这样使得DAAB跟我们的.NET类库的结合更加紧密,回忆一下我们在1.1里面用DBCommandWrapper来访问数据时的代码:

Databasedb=DatabaseFactory.CreateDatabase();
DBCommandWrapperdbCommand=db.GetStoredProcCommandWrapper("GetProductsByCategory");
dbCommand.AddInParameter("CategoryID",DbType.Int32,Category);
DataSetproductDataSet=db.ExecuteDataSet(dbCommand);

而用了新的DBCommand类之后则变成了:

Databasedb=DatabaseFactory.CreateDatabase();
DbCommanddbCommand=db.GetStoredProcCommand("GetProductsByCategory");
db.AddInParameter(dbCommand,"CategoryID",DbType.Int32,Category);
DataSetproductDataSet=db.ExecuteDataSet(dbCommand);

数据库连接字符串在我们基于数据库的开发永远是少不了的,但是在DAAB1.1下,它所使用的字符串跟我们在.NET类库中使用的连接字符串却是不能共享的,它们分别保存在不同的位置。而在2.0的Data Access Application Block使用了ADO.NET2.0里面

<connectionStrings>配置区,这样带来的一个好处是连接字符串可以在Application Block和自定义的.NET类之间共享使用该配置区,如:

<connectionStrings>
<add
name="DataAccessQuickStart"
providerName="System.Data.SqlClient"
connectionString="server=(local)SQLEXPRESS;database=EntLibQuickStarts;Integrated Security=true" />
</connectionStrings>

在.NET2.0下,泛型编程已经成为了一个核心,而2.0版的DAAB中也新增了一个GenericDatabase对象。DAAB中虽然已经包含了SqlDatabase和OrcaleDatabase,但是如果我们需要使用其他的像DB2等数据库时,就需要用到GenericDatabase,它可以用于任何.NET类库中的数据提供者,包括OdbcProvider和OleDbProvider。

二.使用示例

DAAB2.0的配置非常简单,主要有以下几方面的配置:

配置连接字符串