文档介绍:定义总是很抽象。存储进程其实就是能完成一定操作的一组SQL语句,只不过这组语句是放在数据库中的(这里我们只谈SQL SERVER)。如果我们通过创建存储进程以及在ASP中调用存储进程,就可以避免将SQL语句同ASP代码混杂在一起。这样做的好处至少有三个:
第一、大大提高效率。存储进程本身的执行速度非常快,而且,调用存储进程可以大大减少同数据库的交互次数。
第二、提高安全性。假如将SQL语句混合在ASP代码中,一旦代码失密,同时也就意味着库结构失密。
第三、有利于SQL语句的重用。
在ASP中,MAND对象调用存储进程,根据不同情况,本文也介绍其它调用方法。为了方便说明,根据存储进程的输入输出,作以下简单分类:
只返回单一记录集的存储进程
假设有以下存储进程(本文的目的不在于讲述T-SQL语法,所以存储进程只给出代码,不作说明):
/*SP1*/
CREATE PROCEDURE
AS
SET NOCOUNT ON
BEGIN
SELECT * FROM DBO.[USERINFO]
END
GO
以上存储进程取得USERINFO表中的所有记录,返回一个记录集。MAND对象调用该存储进程的ASP代码如下:
'**MAND对象调用存储进程**
DIM M,MYRST
SET M = ("MAND")
= MYCONSTR 'MYCONSTR是数据库连接字串
MANDTEXT = "GETUSERLIST" '指定存储进程名
MANDTYPE = 4 '表明这是一个存储进程
= TRUE '要求将SQL命令先行编译
SET MYRST =
SET M = NOTHING
存储进程取得的记录集赋给MYRST,接下来,可以对MYRST进行操作。
MANDTYPE属性表明请求的类型,取值及说明如下:
1 MANDTEXT参数的类型无法确定
MANDTEXT是一般的命令类型
MANDTEXT参数是一个具有的表名称
4 MANDTEXT参数是一个存储进程的名称
还可以通过CONNECTION对象或RECORDSET对象调用存储进程,方法分别如下:
'**通过CONNECTION对象调用存储进程**
DIM MYCONN,MYRST
SET MYCONN = ("")
MYCONSTR 'MYCONSTR是数据库连接字串
SET MYRST = ("GETUSERLIST",0,4) 'MANDTYPE
SET MYCONN = NOTHING
'**通过RECORDSET对象调用存储进程**
DIM MYRST
SET MYRST = ("")
"GETUSERLIST",MYCONSTR,0,1,4
'MYCONSTR是数据库连接字串,MANDTYPE相同
没有输入输出的存储进程
请看以下存储进程:
/*SP2*/
CREATE PROCEDURE
AS
SET NOCOUNT ON
BEGIN
DELETE FROM DBO.[USERINFO]
END
GO
该存储进程删去USERINFO表中的所有记录,没有任何输入及输出,调用方法与上面讲过的基本相同,只是不用取得记录集:
'**MAND对象调用存储进程**
DIM M
SET M = ("MAND")
= MYCONSTR 'MYCONSTR是数据库连接字串
MANDTEXT = "DELUSERALL" '指定存储进程名
MANDTYPE = 4 '表明这是一个存储进程
= TRUE '要求将SQL命令先行编译
'此处不必再取得记录集
SET M = NOTHING
当然也可通过CONNECTION对象或RECORDSET对象调用此类存储进程,不过建立RECORDSET对象是为了取得记录集,在没有返回记录集的情况下,MAND对象吧。
有返回值的存储进程
在进行类似SP2的操作时,应充分利用SQL SERVER强大的事务处理功能,以维护数据的一致性。并且,我们可能需要存储进程返回执行情况,为此,将SP2修改如下:
/*SP3*/
CREATE PROC