ASP开发中存储过程应用全接触(2)


Set MyComm = Nothing  
  存储过程取得的记录集赋给MyRst,接下来,可以对MyRst进行操作。  

  在以上代码中,CommandType属性表明请求的类型,取值及说明如下:  

  -1 表明CommandText参数的类型无法确定  
  1 表明CommandText是一般的命令类型  
  2 表明CommandText参数是一个存在的表名称  
  4 表明CommandText参数是一个存储过程的名称  

  还可以通过Connection对象或Recordset对象调用存储过程,方法分别如下:  

'**通过Connection对象调用存储过程**  
DIM MyConn,MyRst  
Set MyConn = Server.CreateObject("ADODB.Connection")  
MyConn.open MyConStr 'MyConStr是数据库连接字串  
Set MyRst = MyConn.Execute("getUserList",0,4) '最后一个参断含义同CommandType  
Set MyConn = Nothing  

'**通过Recordset对象调用存储过程**  
DIM MyRst  
Set MyRst = Server.CreateObject("ADODB.Recordset")  
MyRst.open "getUserList",MyConStr,0,1,4  
'MyConStr是数据库连接字串,最后一个参断含义与CommandType相同  
  2. 没有输入输出的存储过程  

  请看以下存储过程:  

/*SP2*/  
CREATE PROCEDURE dbo.delUserAll  
as  
set nocount on  
begin  
delete from dbo.[userinfo]  
end  
go  
  该存储过程删去userinfo表中的所有记录,没有任何输入及输出,调用方法与上面讲过的基本相同,只是不用取得记录
集:  

'**通过Command对象调用存储过程**  
DIM MyComm  
Set MyComm = Server.CreateObject("ADODB.Command")  
MyComm.ActiveConnection = MyConStr 'MyConStr是数据库连接字串  
MyComm.CommandText = "delUserAll" '指定存储过程名  
MyComm.CommandType = 4 '表明这是一个存储过程  
MyComm.Prepared = true '要求将SQL命令先行编译  
MyComm.Execute '此处不必再取得记录集  
Set MyComm = Nothing  
  当然也可通过Connection对象或Recordset对象调用此类存储过程,不过建立Recordset对象是为了取得记录集,在没有
返回记录集的情况下,还是利用Command对象吧。

3. 有返回值的存储过程  

  在进行类似SP2的操作时,应充分利用SQL Server强大的事务处理功能,以维护数据的一致性。并且,我们可能需要存

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/3526.html