Enterprise Library —— Data Access Application Block

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)");//这里也可以进行updatadelete操作

         //设置参数

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);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值