asp学习网: 首页 >> asp与数据库 >> 存储过程 >> 在ASP中使用存储过程其实很简单

在ASP中使用存储过程其实很简单

什么东西知道了都觉得很简单,不知道都觉得很复杂。不过真正了解之后由发现其实很复杂:总而言之,讨论简单和复杂没有什么意义。

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

我们可以创建一个存储过程:
Create PROCEDURE sp_employ
AS
select ID,Name,Picture,Time,Duty from employ
Go


而SQL语句:
select ID,Name,Picture,Time,Duty from employ where ID=10230[quote]
对应的存储过程是:(用Alter替换我们已有的存储过程)
[quote]Alter PROCEDURE sp_employ
@inID int
AS
select ID,Name,Picture,Time,Duty from employ where ID=@inID
Go


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

再看看如何执行Stored Procedure(www.aspxuexi.com):
<%
dim Conn, strSQL, rs
set Conn = Server.CreateObject("ADODB.Connection")
Conn.Open "DSN=webData;uid=user;pwd=password" ’make connection
strSQL = "sp_employ"
Set rs = Conn.Execute(strSQL)
%>


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

from:asp学习网/title:在ASP中使用存储过程其实很简单/ time:2007-11-25 11:31:50

本文主题存储过程

存储过程入门到精通

SQL SERVER存储过程动态SQL的实现

一个改进过的SQL SERVER 2000分页存储过程

通用分页存储过程

一个比较好的分页存储过程

sql server存储过程、存储函数的加密、解密

一个容易忽视的存储过程问题

无限级分类的非递归实现(存储过程版)

asp教程 ©2006-2007 aspxuexi.com | 关于站点 | 版权隐私 | 站内搜索
复制或者翻版 请于夜间进行