程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> ASP編程 >> 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
對應的存儲過程是:(用Alter替換我們已有的存儲過程)
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:
<%
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)
%>


你可能覺得在ASP中使用存儲過程原來是這樣的簡單。對!就是這麼簡單。

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved