学会在ASP中使用存储过程

学习使用存储过程(StoredProcedure),是ASP程序员的必须课之一。所有的大型数据库都支持存储过程,比如Oracle、MSSQL等,(但MSAccess不支持,不过,在Access里可以使用参数化的查询)。
使用存储过程有许多好处,它可以封装复杂的数据逻辑,充分发挥大型数据库本身的优势。我们知道,ASP并不适合做复杂的数据运算,而通过OLDDB访问数据库,由于数据需要在ASP和数据库之间传递,相当消耗系统资源。事实上,如果数据库仅仅起着数据存储的作用,那么它的功能是远远没有得到利用的。
关于如何创建存储过程,请参考MSSQL的相关文档。
本文介绍存储过程如何在ASP中运用。
简单的一个SQL语句:
selectID,Name,Picture,Time,Dutyfromemploy
我们可以创建一个存储过程:
CREATEPROCEDUREsp_employ
AS
selectID,Name,Picture,Time,Dutyfromemploy
Go

而SQL语句:
selectID,Name,Picture,Time,DutyfromemploywhereID=10230
对应的存储过程是:(用Alter替换我们已有的存储过程)
ALTERPROCEDUREsp_employ
@inIDint
AS
selectID,Name,Picture,Time,DutyfromemploywhereID=@inID
Go


下面对比一下SQL和存储过程在ASP中的情况。首先看看直接执行SQL的情况:
<%
dimConn,strSQL,rs
setConn=Server.CreateObject("ADODB.Connection")
Conn.Open"DSN=webData;uid=user;pwd=password"
strSQL="selectID,Name,Picture,Time,Dutyfromemploy"
Setrs=Conn.Execute(strSQL)
%>


再看看如何执行StoredProcedure:
<%
dimConn,strSQL,rs
setConn=Server.CreateObject("ADODB.Connection")
Conn.Open"DSN=webData;uid=user;pwd=password"’makeconnection
strSQL="sp_employ"
Setrs=Conn.Execute(strSQL)
%>


而执行带参数的StoredProcedure也是相当类似的:
<%
dimConn,strSQL,rs,myInt
myInt=1
setConn=Server.CreateObject("ADODB.Connection")
Conn.Open"DSN=webData;uid=user;pwd=password"
strSQL="sp_myStoredProcedure"&myInt
Setrs=Conn.Execute(strSQL)
%>


你可能觉得在ASP中使用存储过程原来是这样的简单。对!就是这么简单。

转自: http://goaler.xicp.net/ShowLog.asp?ID=503

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值