Data Access Application Block:数据库访问应用程序块,提供了一个简单的数据库访问方式。
1.对数据库访问提供了简单、高效的访问方式
减少编写重复累赘代码去执行标准的数据访问任务
易于使用,使用单条语句即可完成Stored Procedure的调用
屏蔽了对常用ADO.NET使用的复杂度,提供了基于最佳实践,正确快速使用接口
2.对不同类型的数据库(SQLServer/Oracle/DB2)提供了编程上的透明性
为不同数据库类型提供了统一的编程
当移植应用程序到不同数据库类型时,减少重写代码的数量(移植时需要注意一些数据类型在不同数据库中的不同方式,需要适当修改代码)
3.搭起了逻辑数据库与物理数据库之间的桥梁,降低改变物理数据库目标的难度(编程时不需关心使用的什么数据库、放在哪里,在程序里仅是一个字符串,对于具体在哪、什么数据库都是在配置时通过配置工具去实现的)
4.增强的数据库联接串的安全性
5.容易对数据库访问的配置信息进行调整和验证
6. 项目实例(这里使用的是Enterprise Library4.0,现在好像出到了5.0)
(1)下载安装EL,下载地址:
http://www.microsoft.com/downloads/details.aspx?FamilyId=90DE37E0-7B42-4044-99BE-F8ECFBBC5B65&displaylang=en&displaylang=en
(2)这样就可以直接使用Enterprise Library的配置工具直接打开asp.net中的web.config文件。如图:
打开之后:
右键单击connection strings新建一个connection string:
建立好之后可以点开属性可以进行对应的修改,本人这里使用了vs2008集成打开,如图:
ConnectionString表示对应的链接字符串。
Name是制定一个Connection String的名称,便于之后在程序中进行调用。
ProviderName是表示选择提供的对应数据库。
(3)对数据库字符串加密,选择Data Access Application Block节点,属性中会出现如图:
这里设置protectionProvider的即可,这里有两个可以选择,一个是RsaProtectedConfigurationProvider,另一个是DataProtectedConfigurationProvider。具体两者的区别见博文:http://blog.csdn.net/shellwin/archive/2010/07/08/5721072.aspx。这里我选择的是前者。到这里整个配置便完成了,你可以打开web.config文件查看,发现已经进行相应的加密。但是个人建议在我们做开发的过程中,这个可以不用加密,等发布的时候进行加密。
7.程序实现
(1)定义一个连接方法得到Database,方法主要方法是:
Database database = DatabaseFactory.CreateDatabase("Connection String");
(2)得到Database后可以进行相应的CRUD操作,代码:
IDataParameter param = null;
DbCommand command = this.database.GetSqlStringCommand("insert into information (i_title) values (@i_title)");//这里也可以进行updata和delete操作
//设置参数
param = new SqlParameter();
param.ParameterName = "@i_title";
param.Value = t.I_title;
param.DbType = DbType.String;
command.Parameters.Add(param);
//执行操作
int temp = this.database.ExecuteNonQuery(command);
(3)执行存储过程,代码如下:
IDataParameter param = null;
DbCommand command = this.database.GetStoredProcCommand("sp_xxx");
//设置参数
param = new SqlParameter();
param.ParameterName = "@tblName";
param.Value = tableName;
param.DbType = DbType.String;
command.Parameters.Add(param);
//执行操作
return this.database.ExecuteDataSet(command);