技术开发 频道

Enterprise Library2.0(1):Data Access Application Block学习


【IT168技术文档】

  Data Access Application Block提供了通用的数据访问的功能,随着2.0版本的推出有了很大变化。

一.改进

  在DAAB1.1里面我们知道Database方法返回或者创建一个DBCommandWrapper对象,而在DAAB2.0里面移除了DBCommandWrapper类,用ADO.NET2.0里面的DBCommand类代替实现类似的功能,这样使得DAAB跟我们的.NET类库的结合更加紧密,回忆一下我们在1.1里面用DBCommandWrapper来访问数据时的代码:
Database db = DatabaseFactory.CreateDatabase(); DBCommandWrapper dbCommand = db.GetStoredProcCommandWrapper("GetProductsByCategory"); dbCommand.AddInParameter("CategoryID", DbType.Int32, Category); DataSet productDataSet = db.ExecuteDataSet(dbCommand);
  而用了新的DBCommand类之后则变成了:
Database db = DatabaseFactory.CreateDatabase(); DbCommand dbCommand = db.GetStoredProcCommand("GetProductsByCategory"); db.AddInParameter(dbCommand, "CategoryID", DbType.Int32, Category); DataSet productDataSet = 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的配置非常简单,主要有以下几方面的配置:

  配置连接字符串
0
相关文章