分享
 
 
 

DataAccessApplicationBlock概述

王朝other·作者佚名  2008-05-19
窄屏简体版  字體: |||超大  

简介

您是否正在从事 .NET 应用程序数据访问代码的设计和开发?您是否觉得自己总是在反复编写相同的数据访问代码?您是否曾经将数据访问代码包装在 Helper 函数中,以便能够在一行中调用存储过程?如果是,那么 Microsoft? Data Access Application Block for .NET 正是为您设计的。

Data Access Application Block 将访问 Microsoft SQL Server? 数据库的性能和资源管理方面的最佳经验封装在一起。您可以很方便地在自己的 .NET 应用程序中将其作为构造块使用,从页减少了需要创建、测试和维护的自定义代码的数量。

尤其是,Data Access Application Block 可以帮助您:

调用存储过程或 SQL 文本命令。

指定参数详细信息。

返回 SqlDataReader、DataSet 或 XmlReader 对象。

例如,在引用了 Data Access Application Block 的应用程序中,您可以简单地在一行代码中调用存储过程并生成 DataSet,如下所示:

[Visual Basic]

Dim ds As DataSet = SqlHelper.ExecuteDataset( _

connectionString, _

CommandType.StoredProcedure, _

"getProductsByCategory", _

new SqlParameter("@CategoryID", categoryID))

[C#]

DataSet ds = SqlHelper.ExecuteDataset(

connectionString,

CommandType.StoredProcedure,

"getProductsByCategory",

new SqlParameter("@CategoryID", categoryID));

注意: Application Block for .NET(用于 .NET 的应用程序块)是基于对成功的 .NET 应用程序进行详细研究而设计的。它以源代码的形式提供,您可以原样使用,也可以针对自己的应用程序进行自定义。该应用程序块并不代表未来 Microsoft ADO.NET 程序库的发展方向。Microsoft ADO.NET 程序库是为在各种使用情况下实现对数据访问行为的精确控制而建立的。将来的 ADO.NET 版本可能会使用不同的模型来实现这个方案。

Data Access Application Block 包括哪些内容?

提供了 Data Access Application Block 的源代码以及快速入门示例应用程序,您可以使用这些应用程序测试其功能。Data Access Application Block 还包括综合文档,可以帮助您使用和了解所提供的代码。

Visual Studio .NET 项目

提供了 Data Access Application Block 的 Microsoft Visual Basic? .NET 和 Microsoft Visual C#? 源代码,以及每种语言的快速入门示例客户端应用程序,您可以使用这些应用程序测试常见的方案。这有助于加深您对 Data Access Application Block 的工作原理的了解。您还可以自定义源代码以满足自己的需要。

您可以编译 Visual Basic 和 C# Microsoft.ApplicationBlocks.Data 项目,以生成一个名为 Microsoft.ApplicationBlocks.Data.dll 的程序集。该程序集包括一个 SqlHelper 类(其中包含用于执行数据库命令的核心功能)和一个 SqlhelperParameterCache 类(提供参数发现和缓存功能)。

文档

Data Access Application Block 的文档主要包括以下内容:

使用 Data Access Application Block 开发应用程序。本部分包括快速入门示例,其中包含多种常见的使用情况,可以帮助您快速轻松地掌握 Data Access Application Block(数据访问应用程序块)的使用。

Data Access Application Block 的设计与实现。本部分包括背景设计原理信息,以便用户深入了解 Data Access Application Block 的设计与实现。

部署和运行。本部分包括安装信息,其中包含部署和更新选项以及与安全性有关的信息。

参考。本部分包含综合的 API 参考,其中详细介绍了构成 Data Access Application Block 的类和接口。

系统要求

要运行 Data Access Application Block,需要满足以下要求:

Microsoft Windows? 2000、Windows XP Professional

.NET Framework SDK(英文)的 RTM 版本

Visual Studio? .NET 的 RTM 版本(推荐,但不必需)

SQL Server 7.0 或更高版本的数据库服务器

下载并安装 Data Access Application Block

您可以获取一个包含已签名的 Data Access Application Block 程序集和综合文档的 Windows 安装程序文件。

安装进程将在您的“程序”菜单中创建一个 Microsoft Application Blocks for .NET(用于 .NET 的 Microsoft 应用程序块)子菜单。该子菜单中有一个 Data Access(数据访问)子菜单,其中包括用于启动文档的选项和用于启动 Data Access Application Block Visual Studio .NET 解决方案的选项。

请转到 MSDN Downloads(英文)进行下载。

使用 Data Access Application Block

本节讨论如何使用 Data Access Application Block 来执行数据库命令和管理参数。图 1 显示了 Data Access Application Block 的主要元素。

图 1:Data Access Application Block

SqlHelper 类提供了一组静态方法,可以用来向 SQL Server 数据库发出许多各种不同类型的命令。

SqlHelperParameterCache 类提供命令参数缓存功能,可以用来提高性能。该类由许多 Execute 方法(尤其是那些只运行存储过程的重写方法)在内部使用。数据访问客户端也可以直接使用它来缓存特定命令的特定参数集。

使用 SqlHelper 类执行命令

SqlHelper 类提供了五种 Shared (Visual Basic) 或 static (C#) 方法,它们是:ExecuteNonQuery、ExecuteDataset、ExecuteReader、ExecuteScalar 和 ExecuteXmlReader。实现的每种方法都提供一组一致的重载。这提供了一种很好的使用 SqlHelper 类来执行命令的模式,同时为开发人员选择访问数据的方式提供了必要的灵活性。每种方法的重载都支持不同的方法参数,因此开发人员可以确定传递连接、事务和参数信息的方式。类中实现的所有方法都支持以下重载:

[Visual Basic]

Execute* (ByVal connection As SqlConnection, _

ByVal commandType As CommandType, _

ByVal CommandText As String)

Execute* (ByVal connection As SqlConnection, _

ByVal commandType As CommandType, _

ByVal commandText As String, _

ByVal ParamArray commandParameters() As SqlParameter)

Execute* (ByVal connection As SqlConnection, _

ByVal spName As String, _

ByVal ParamArray parameterValues() As Object)

Execute* (ByVal transaction As SqlTransaction, _

ByVal commandType As CommandType, _

ByVal commandText As String)

Execute* (ByVal transaction As SqlTransaction, _

ByVal commandType As CommandType, _

ByVal commandText As String, _

ByVal ParamArray commandParameters() As SqlParameter)

Execute* (ByVal transaction As SqlTransaction, _

ByVal spName As String, _

ByVal ParamArray parameterValues() As Object)

[C#]

Execute* (SqlConnection connection, CommandType commandType,

string commandText)

Execute* (SqlConnection connection, CommandType commandType,

string commandText, params SqlParameter[] commandParameters)

Execute* (SqlConnection connection, string spName,

params object[] parameterValues)

Execute* (SqlConnection connection,

CommandType commandType, string commandText)

Execute* (SqlConnection connection,

CommandType commandType, string commandText,

params SqlParameter[] commandParameters)

Execute* (SqlConnection connection,

string spName, params object[] parameterValues)

除这些重载以外,除 ExecuteXmlReader 之外的其他方法还提供了另一种重载:允许将连接信息作为连接字符串而不是连接对象来传递,如下面的方法签名所示:

[Visual Basic]

Execute* (ByVal connectionString As String, _

ByVal commandType As CommandType, _

ByVal commandText As String)

Execute* (ByVal connectionString As String, _

ByVal commandType As CommandType, _

ByVal commandText As String, _

ByVal ParamArray commandParameters() As SqlParameter)

Execute* (ByVal connectionString As String, _

ByVal spName As String, _

ByVal ParamArray parameterValues() As Object)

[C#]

Execute* (string connectionString, CommandType commandType,

string commandText)

Execute* (string connectionString, CommandType commandType,

string commandText,

params SqlParameter[] commandParameters)

Execute* (string connectionString, string spName,

params object[] parameterValues)

注意: ExecuteXmlReader 不

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有