三九宝宝网宝宝百科宝宝知识

让VB实现SQLServer2000存储过程调用

11月26日 编辑 39baobao.com

[excle表格中的方法如何调用]2然后在A1表格中输入内容,等一下,我们要在VBA编辑器中获取到A1的值。3打开VBA编辑器,新建一个过程。4方法的调用格式是Object.Property,Object代表对象,Property代表想法。dat...+阅读

存储过程

存储过程是存储在服务器上的一组预编译的Transact-SQL语句,是一种封装重复任务操作的方法,支持用户提供的变量,具有强大的编程功能。它类似于DOS系统中的BAT文件。在BAT文件中,可以包含一组经常执行的命令,这组命令通过BAT文件的执行而被执行。同样的道理,可以把要完成某项任务的许多Transact-SQL语句写在一起,组织成存储过程的形式,通过执行该存储过程就可以完成这项任务。存储过程与BAT文件又有差别,即存储过程已经进行了预编译。

1、创建存储过程的方法:

在Transact-SQL语言中,创建存储过程可以使用CREATE PROCEDURE语句,其语法形式如下:

CREATE PROC[EDURE] procedure_name[;number]

[{#parameter data_type}[VARYING][=default][OUTPUT]

]],…n]

[WITH{REPILE|ENCRYPTION|REPILE,ENCRYPTION}]

FOR REPLICATION]

AS sql_statement[…n]

在上面的CREATE PROCEDURE语句中,方括号"[ ]"中的内容是可选的,花括号"{}"中的内容是必须出现的,不能省略,[,…n]表示前面的参数样式,可以重复出现。竖线"|"表示两边的选项可以任选一个。

下面分析该语句中各种选项的含义。

CREATE PROCEDURE是关键字,也可以写成CREATE PROC。

procedure_name是该存储过程的名称,名称可以是任何符合命名规则的标示符。名称后的[;number]参数表示可以定义一系列的存储过程名称,这些存储过程的数量由number指定。

参数名称可以使用#parameter data_type来指定。在Transact-SQL语言中,用户定义的参数名称前面加“#”符号,这些数据类型是Transact-SQL语言允许的各种数据类型,包括系统提供的数据类型和用户定义的数据类型。

当参数类型为cursor时,必须使用关键字VARYING和OUTPUT。VARYING表示结果集可以是一个输出参数,其内容是动态的。该关键字只能在使用游标作为数据类型时使用。关键字OUTPUT表示这是一个输出参数,可以把存储过程执行的结果信息返回应用程序。

default用于指定参数的默认值。

选项表示重新编译该存储过程。该选项只是在需要的时候才使用,例如经常需要改变数据库模式时。

ENCRYPTION选项用来加密创建存储过程的文本,防止他人查看。

选项FOR REPLICATION主要用于复制过程中。注意,该选项不能和选项REPILE同时使用。

AS是一个关键字,表示其后的内容是存储过程的语句。参数sql-statement[…n]表示在一个存储过程中可以包含多个Transact-SQL语句。

2、存储过程的优点:

在频繁访问数据库的系统中,开发者都乐于使用存储过程,这与存储过程的下列优点是分不开的。

⑴ 存储过程可以与其他应用程序共享应用程序的逻辑,从而确保一致的数据访问和操纵。

⑵ 存储过程提供了一种安全机制。如果用户被授予执行存储过程权限,那么即使该用户没有访问在执行该存储过程中所参考的表或视图的权限,该用户也可以完全执行该存储过程而不受到影响。因此,可以创建存储过程来完成所有的增加、删除等操作,并且可以通过编程控制上述操作中对信息的访问权限。

⑶存储过程执行速度快,便于提高系统的性能。由于存储过程在第一次执行之后,其执行规划就驻存在过程高速缓冲存储区中,在以后的操作中,只需从过程高速缓冲存储区中调用编译好的二进制形式存储过程来执行。

⑷ 使用存储过程可以减少网络传输时间。如果有一千条Transact-SQL语句的命令,一条一条地通过网络在客户机和服务器之间传送,那么这种传输所耗费的时间将很长。但是,如果把这一千条Transact-SQL语句的命令写成一条较为复杂的存储过程命令,这时在客户机和服务器之间网络传输所需的时间就会大大减少。

SQL Server 2000数据库存储过程的调用

VB作为当今应用极为普遍的数据库客户端开发工具之一,对客户端应用程序调用服务器端存储过程提供了强大的支持。特别是随着VB6.0的推出,VB客户端应用程序可以方便地利用ADO的对象和集合来实现对数据库存储过程的调用。

在笔者编写的科技档案管理系统中,就是采用VB作为开发平台,采用SQL Server2000数据库管理数据,在这个科技档案管理系统中有海量的数据,并且对数据库有频繁的访问,利用存储过程访问数据库节省了执行时间,大大提高了系统的性能。

1、ADO简介:

ADO控件(也称为ADO Data控件)与VB固有的Data控件相似。使用ADO Data控件,可以利用Microsoft ActiveX Data Objects(ADO)快速建立数据库绑定控件和数据提供者之间的连接。

ADO Data控件可以实现以下功能:

·连接一个本地数据库或远程数据库。

·打开一个指定的数据库表,或定义一个基于结构化查询语言(SQL)的查询、存储过程或该数据库中的表的视图的记录集合。

·将数据字段的数值传递给数据绑定控件,可以在这些控件中显示或更改这些数值。

·添加新的记录,或根据更改显示在绑定的控件中的数据来更新一个数据库。

2、数据库的连接:

数据库的连接可通过ADO控件实现,为此,必须在工程部件中选择Microsoft ADO Data Control 6.0 (OLEDB),然后在窗体中添加ADO控件。利用ADO连接数据库有两种方法,具体如下。

1) 通过ADODC属性页实现连接:

在ADODC属性页中选择生成按钮,进入数据链接属性对话框;然后选择该对话框中的连接属性页,选择或输入服务器名称和数据库等重要信息;最后测试连接,连接成功后,按确定按钮,返回到属性页对话框,可获得连接字符串,如下例:

Provider=SQLOLEDB.1;Persist

Security Info=False;

User ID=sa;Initial Catalog=Science_File;

Data Source=Data_Server

其中sa是用户名;Science_File是数据库名;Data_Server是数据库名。

通过下列语句,即可连接到指定的数据库:

dim odbcstr as String,

adocon As New ADODB.Connection

odbcstr = "Provider=SQLOLEDB.1;

Persist Security Info=False;User ID=sa;

Initial Catalog=Science_File;Data Source=Data_Server"

adocon.Open odbcstr ''连接到数据库

2) 直接使用连接语句实现:

连接数据库的语句如下:

Dim ado as ADODC

ado.ConnectionString =

"Provider=SQLOLEDB.1;Password="

Persist Security

Info=True;User Data'定义一变量。

Dim adoconn As New ADODB.Connection

''Connection 对象代表了打开与数据源的连接。

Dim adom As New ADODB.mand

''mand 对象定义了将对数据源执行的指定命令。

Dim ReturnValue As Integer

''调用存储过程的返回值。

adoconn.ConnectionString = Adodc1.ConnectionString

''Adodc1为窗体中的ADO控件,并已成功连接数据库。

adoconn.Open

Set adom.ActiveConnection = adoconn

''指示指定的 mand对象当前所属的 Connection对象。

adom.mandText = "doc_ProcName"

''设置mand对象源。

adom.mandType = adCmdStoredProc

''通知提供者mandText属性有什么,它可能包括mand对象的源类型。

设置这个属性优化了该命令的执行。

adom.Parameters(1) = "1"

adom.Parameters(2) = "OutputParameters"

''OutputParameters可以为任意的字符串或数字。

adom.Execute

ReturnValue = adom.Parameters(0)

''存储过程的返回值,返回0则成功执行。

strS = adom.Parameters(2)

''把存储过程的输出参数的值赋给变量strS。

2) 追加参数法调用存储过程:

追加参数通过CreateParameter方法,用来指定属性创建新的Parameter对象。具体语法如下:

Set parameter = mand.CreateParameter (Name, Type, Direction, Size, Value)

·Name 可选,字符串,代表 Parameter 对象名称。

·Type 可选,长整型值,指定 Parameter 对象数据类型。

·Direction 可选,长整型值,指定 Parameter 对象类型。

·Size 可选,长整型值,指定参数值长度(以字符或字节数为单位)。

·Value 可选,变体型,指定 Parameter 对象值。

这种方法与上面一种方法的分别主要在于,追加参数的方法在向存储过程传递参数时,这种方法首先通过CreateParameter方法为存储过程创建参数,然后通过Append方法将创建的参数追加到Parameters集合中去。

仍然以存储过程doc_ProcName的调用为例,关键代码如下:

Dim mRst As ADODB.Recordset

''Recordset 对象表示的是来自基本表

或命令执行结果的记录全集。

Dim prm As ADODB.Parameter

''Parameter 对象代表参数或

与基于参数化查询或存储过程的mand 对象相关联的参数。

adoconn.ConnectionString = Adodc1.ConnectionString

adoconn.Open

Set adom.ActiveConnection = adoconn

adom.mandText = "doc_ProcName"

adom.mandType = adCmdStoredProc

Set prm = adom.CreateParameter

("parameter1", adTinyInt, adParamInput, , "1")

adom.Parameters.Append prm

Set prm = adom.CreateParameter

("parameter2", adInteger, adParamOutput)

adom.Parameters.Append prm

Set mRst = adom.Execute

ReturnValue = adom.Parameters(0)

以上代码中未定义的变量以及未注释的语句与前述相同。

结束语

在应用程序中调用服务器端存储过程,不仅能显著提高整个应用的性能,而且能加强对数据库数据的保护。VB为客户端应用程序调用存储过程提供了一组方便而有效的方法。

以下为关联文档:

无法创建SqlServer数据库的问题最初安装Visual Studio 2008 时还好,不知道什么时候,应该是安装了SQL Server Management Studio Express 以后,Visual Studio 2008 不能连接 SQL Server 2005了。只好重装,可是...

SQLServersqlplus中host命令出现lsSQL-- 奇怪 sqlplus中 host命令出现lsSQLSQL>hostlsSQL>SQL>SQL>除了lsSQL>提示外,没有什么反应,为什么?当然,退出后重新进入,又可以正常使用HOST命令了.Examda提示产生...

SQLServerweblogic配置连接池问题在配置连接池的时候有时会出现“JDBC driver is not on the CLASSPATH”这是因为我们的创建连接池所需要的驱动相应数据库jar包没有找到比如拿sqlserver2000来举例:创建s...

SQLServer2005配置Windows即时初始化SQL Server 2005支持数据库即时文件初始化(Instant File Initialization),这种即时文件初始化可以跳过清零数据的页面,这样做可以在执行一些操作,比如创建数据库,增加文件到现有...

浅析SQLServer2008企业级新特性微软SQL Server 2008的开发代号是Katmai,这个名字来源于阿拉斯加半岛东端阿拉斯加州北部阿留申山区的一座活火山,对数据库而言,可能并不是个的比喻(嘿嘿,目前为止,Katmai火山还没...

调用EclipseCDT解析器的结果实现对C++代码的解析引入.eclipse.cdt.core的插件包后.通过如下代码则可获得某个C++源文件的解析结果public static IASTTranslationUnit getAST( IFile file) {ITranslationUnit tu = CoreMo...

微软SQLServer2008数据库中的新数据类型对于关系型数据库来说,表现树状的层次结构始终是一个问题。微软在SQL Server 2005中首次尝试了解决这个问题,那就是被称之为通用数据表表达式(mon Table Expressions,CTE)的实...

SQLServerSql内存不足探索sql2005 报告内存不足,我们的服务器 16G 内存,根据以往经验,这个够了,但是为什么还报告这个错误?这台服务器连接的Server 比较多,据推断可能与连接的Server 有关系;网上看到sql内...

SQLServer2000工具的中英文互换SQL Server 2000 扩展了 Microsoft SQL Server 7.0 版的性能、可靠性、质量和易用性,对于中国用户来说,这是Microsoft SQL Server的第一个全汉化产品,尤其是其强大的联机帮助,为...

推荐阅读
图文推荐