打印本文 打印本文  关闭窗口 关闭窗口
几例在ASP存储过程的使用方法
作者:采集员 文章来源:来源于网络 点击数: 更新时间:2005/9/10 13:25:53
rver的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);

3.使用VB6.0,打开菜单“视图”/“数据视图窗口”后,右键单击“数据链接”/“新建数据链接”;

4.使用ASP脚本创建存储过程,例wuf75.asp:

<% @LANGUAGE = VBScript %>

<!--#include file="AdoSQL7.asp"-->

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

<% ' wuf75.asp

Dim StrSQL

'注: & Chr(10) & Chr(13) 完全可以不要, 主要是为了好看

StrSQL="CREATE PROCEDURE OUTemploy ( @job_lvl tinyint OUTPUT, " & Chr(10) & Chr(13) &_

       "@hire_date1 datetime, @hire_date2 datetime) AS " & Chr(10) & Chr(13) &_

       "select @job_lvl = MAX(job_lvl) from employee " &_

       "where hire_date >= @hire_date1 and hire_date <= @hire_date2"

 

Cnn.Execute StrSQL

Response.Write "创建存储过程成功"

Cnn.close: Set Cnn = Nothing

%>

    存储过程创建后,除了使用菜单,你还可以使用SQL语句“Drop Procedure OUTemploy”删除它。

    例wuf72.asp ? 把所需要的输入参数送入存储过程并取得输出结果。

<% @LANGUAGE = VBScript %>

<!--#include file="AdoSQL7.asp"-->

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

<% ' wuf72.asp

Dim cmdTest, prmTest

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

cmdTest.ActiveConnection = Cnn

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

cmdTest.CommandType = adCmdStoredProc

 

'创建 Parameter 对象

Set prmTest = cmdTest.CreateParameter("job_lvl",adTinyInt,adParamOutput)

cmdTest.Parameters.Append prmTest

'adTinyInt - 1 字节带符号整型

'adDbDate - 日期值 (yyyymmdd)

 

Set prmTest = cmdTest.CreateParameter("hiredate1",adDBDate,adParamInput,,"1993-05-09")

cmdTest.Parameters.Append prmTest

 

Set prmTest = cmdTest.CreateParameter("hiredate2",adDBDate,adParamInput,,"1994-02-01")

cmdTest.Parameters.Append prmTest

 

cmdTest.Execute

‘下面三种表达方式意思一样

Response.Write cmdtest("job_lvl") & "<br>"

Response.Write cmdTest.Parameters("job_lvl") & "<br>"

Response.Write cmdTest.Parameters("job_lvl").Value

 

Cnn.close

Set prmTest = Nothing

Set cmdTest = Nothing: Set Cnn = Nothing

%>

(三)使用返回代码参数

用Return语句可以从存储过程返回不同的返回代码,如下面存储过程先取得一个记录集,然后,若有叫Margaret的雇员则返回1,否则返回0。

Create Procedure Returnemploy

AS

select emp_id, fname from employee

If Exists(Select fname From employee Where fname='Margaret')

       Return(1)

Else

       Return(0)

例wuf73.asp

<% @LANGUAGE = VBScript %>

<!--#include file="AdoSQL7.asp"-->

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

<% ' wuf73.asp

Dim cmdTest, prmTest, rsTest

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

cmdTest.ActiveConnection = Cnn

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

cmdTest.CommandType = adCmdStoredProc

 

Set prmTest = cmdTest.CreateParameter("ReturnValue",adInteger,adParamReturnValue)

cmdTest.Parameters.Append prmTest

 

Set rsTest = cmdTest.Execute()

While Not rsTest.EOF

       Response.Write rsTest(0) & " ][ " & rsTest(1) & "<br>"

       rsTest.MoveNext

Wend

rsTest.Close: Set rsTest = Nothing

'返回 cmdtest("ReturnValue") 之前,必须先关闭rsTest, 否则结果错误

 

If cmdtest("ReturnValue") = 1 Then

       Response.Write "有该雇员"

Else

       Response.Write "无该雇员"

End If

 

Cnn.close

Set prmTest = Nothing

Set cmdTest = Nothing: Set Cnn = Nothing

%>

 

三、如何处理大数据

这里的“大数据”主要是指Text(大文本)和image(图像)字段,采用前面所述的方法无法正确获取其数据。必须首先使用Size = rsTest(0).ActualSize获取字段值的实际长度,然后再使用rsTest(0).GetChunk(Size)取得数据。在实际使用过程中,由于这些字段都比较大,为了节省、合理使用服务器资源,一般均采取分段读取的方法。例wuf74.asp:

<% @LANGUAGE = VBScript %>

<!--#include file="AdoSQL7.asp"-->

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

<% ' w

上一页  [1] [2] [3]  下一页



打印本文 打印本文  关闭窗口 关闭窗口