几例在ASP存储过程的使用方法(3)



!--#include file="adovbs.inc"-->

% '' wuf71.asp

Dim cmdTest, prmTest, rsTest

Set cmdTest = Server.CreateObject("ADODB.Command")

cmdTest.CommandText = "byroyalty" ''存储过程名

''设命令类型为 存储过程

cmdTest.CommandType = adCmdStoredProc


''创建 Parameter 对象

Set prmTest = Server.CreateObject("ADODB.Parameter")

‘Type属性对应wuf70.asp中的第二个参数

prmTest.Type = adInteger ''4 字节的带符号整型

‘Direction属性对应wuf70.asp中的第三个参数

prmTest.Direction = adParamInput

‘Value属性对应wuf70.asp中的第五个参数

prmTest.Value = 30

cmdTest.Parameters.Append prmTest


Set cmdTest.ActiveConnection = Cnn

‘需要返回一个记录集,故使用Set rsTest = cmdTest.Execute

Set rsTest = cmdTest.Execute


While Not rsTest.EOF

Response.Write rsTest(0) & " "

rsTest.MoveNext

Wend


Cnn.close

Set rsTest = Nothing : Set prmTest = Nothing

Set cmdTest = Nothing: Set Cnn = Nothing

%>

CommandText属性既可以指定SQL命令,也可以指定为存储过程或者是表名称。

在本例中,创建Parameter对象与wuf70.asp略有不同,其实仔细看看,意思也是差不多的,本例还有两个属性未用:prmTest.Name、prmTest.Size,加上Type、Direction和Value,对应于wuf70.asp中的五个参数。


(二)使用输出参数

从数据库表中取得一个记录或计算一个值时,需要使用返回输出参数的存储过程。为了举例,先在SQL Server的pubs库中新建一存储过程OUTemploy,该存储过程需要输入两个日期,然后输出一个最大值。

CREATE PROCEDURE OUTemploy

(

@job_lvl tinyint OUTPUT,

@hire_date1 datetime, 

@hire_date2 datetime 

)

AS

select @job_lvl = MAX(job_lvl) from employee

where hire_date >= @hire_date1 and hire_date = @hire_date2

有多种方法可以建立存储过程:

1.使用Microsoft SQL Server的Enterprise Manager,打开后在左边的树目录中依次打开:Console Root – Microsoft SQL Servers – SQL Server Group – ICBCZJP(Windows NT) – databases – pubs – stored procedure – New stored procedure,输入存储过程后,还可对其进行语法检测;

2.使用Microsoft SQL Server的Query Analyzer,先连接数据库服务器并选择pubs数据库。输入上面的存储过程并点击Execute Query(或按F5);

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

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