国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

ASP調用帶參數存儲過程的幾種方式

2024-05-04 11:05:40
字體:
來源:轉載
供稿:網友

ASP調用帶參數存儲過程的幾種方式,我們都了解嗎?開發程序的時候我們都必須要結合實際情況進行操作,今天就跟著錯新技術頻道小編的步伐來學習吧!

ASP調用帶參數存儲過程的幾種方式?????選擇自?hxfwsk?的?Blog??
關鍵字???存儲過程?
出處????

?作者:?討飯貓

ASP調用帶參數存儲過程的幾種方式

最近有很多的朋友問到調用存儲過程的問題,這里簡單介紹幾種ASP調用帶參數存儲過程的方法。

1?這也是最簡單的方法,兩個輸入參數,無返回值:
set?connection?=?server.createobject("adodb.connection")
connection.open?someDSN?
Connection.Execute?"procname?varvalue1,?varvalue2"

'將所有對象清為nothing,釋放資源
connection.close
set?connection?=?nothing


2?如果要返回?Recordset?集:
set?connection?=?server.createobject("adodb.connection")
connection.open?someDSN?
set?rs?=?server.createobject("adodb.recordset")
rs.Open?"Exec?procname?varvalue1,?varvalue2",connection

'將所有對象清為nothing,釋放資源
rs.close
connection.close
set?rs?=?nothing
set?connection?=?nothing


3?以上兩種方法都不能有返回值,(Recordset除外),如果要得到返回值,需要用Command的方法。
首先說明,返回值有兩種。一種是在存儲過程中直接return一個值,就象C和VB的函數返回值那樣;另一種是可以返回多個值,存
儲這些值的變量名稱需要在調用參數中先行指定。
這個例子要處理多種參數,輸入參數,輸出參數,返回記錄集以及一個直接返回值(夠全了吧?)
存儲過程如下:

use?pubs
GO

--?建立存儲過程
create?procedure?sp_PubsTest

--?定義三個參數變量,注意第三個,特別標記是用于輸出
@au_lname?varchar?(20),?
@intID?int,
@intIDOut?int?OUTPUT

AS

SELECT?@intIDOut?=?@intID?+?1

SELECT?*?
FROM?authors?
WHERE?au_lname?LIKE?@au_lname?+?'%'

--直接返回一個值
RETURN?@intID?+?2


調用該存儲過程的asp程序如下:

<%@?Language=VBScript?%>
<%
Dim?CmdSP
Dim?adoRS
Dim?adCmdSPStoredProc
Dim?adParamReturnValue
Dim?adParaminput
Dim?adParamOutput
Dim?adInteger
Dim?iVal
Dim?oVal
Dim?adoField
Dim?adVarChar

‘這些值在?VB?中是預定義常量,可以直接調用,但在?VBScript?中沒有預定義
adCmdSPStoredProc?=?4
adParamReturnValue?=?4
adParaminput?=?1
adParamOutput?=?2
adInteger?=?3
adVarChar?=?200

iVal?=?5
oVal?=?3

'建一個command對象
set?CmdSP?=?Server.CreateObject("ADODB.Command")

'建立連結
CmdSP.ActiveConnection?=?"Driver={SQL?Server};server=(local);Uid=sa;Pwd=;Database=Pubs"

'定義command?對象調用名稱?
CmdSP.CommandText?=?"sp_PubsTest"

'設置command調用類型是存儲過程?(adCmdSPStoredProc?=?4)
CmdSP.CommandType?=?adCmdSPStoredProc

'往command?對象中加參數
'定義存儲過程有直接返回值,并且是個整數,省缺值是4
CmdSP.Parameters.Append?CmdSP.CreateParameter("RETURN_VALUE",?adInteger,?adParamReturnValue,?4)
'定義一個字符型輸入參數
CmdSP.Parameters.Append?CmdSP.CreateParameter("@au_lname",?adVarChar,?adParaminput,?20,?"M")
'定義一個整型輸入參數
CmdSP.Parameters.Append?CmdSP.CreateParameter("@intID",?adInteger,?adParamInput,?,?iVal)
'定義一個整型輸出參數
CmdSP.Parameters.Append?CmdSP.CreateParameter("@intIDOut",?adInteger,?adParamOutput,?oVal)

'運行存儲過程,并得到返回記錄集
Set?adoRS?=?CmdSP.Execute


'把每個記錄打印出來,其中的字段是虛擬的,可以不用管
While?Not?adoRS.EOF

for?each?adoField?in?adoRS.Fields
Response.Write?adoField.Name?&?"="?&?adoField.Value?&?"
"?&?vbCRLF
Next
Response.Write?"
"
adoRS.MoveNext
Wend

'打印兩個輸出值:
Response.Write?"

@intIDOut?=?“?&?CmdSP.Parameters("@intIDOut").Value?&?"

"
Response.Write?"

Return?value?=?"?&?CmdSP.Parameters("RETURN_VALUE").Value?&?"

"


'大掃除
Set?adoRS?=?nothing
Set?CmdSP.ActiveConnection?=?nothing
Set?CmdSP?=?nothing
%>


asp調用數據庫存儲過程?????選擇自?11830?的?Blog??
關鍵字???asp,數據庫,存儲過程?
出處????

asp調用數據庫存儲過程????

<%Set?Dataconn?=?Server.CreateObject("ADODB.Connection")?
'建立連接對象
Dataconn.Open?"DSN=SinoTrans;SERVER=APP_SERVER;UID=sa;PWD=;APP=Microsoft(R)?Developer?Studio;WSID=APP_SERVER;Regional=Yes"
Set?cmdTemp?=?Server.CreateObject("ADODB.Command")
'建立命令對象
Set?rst?=?Server.CreateObject("ADODB.Recordset")?
'建立記錄集對象
cmdTemp.CommandText?=?"dbo.pd_test"?'存儲過程名稱
cmdTemp.CommandType?=?4?
'命令類別為4,表示為存儲過程
Set?cmdTemp.ActiveConnection?=?Dataconn
Set?tmpParam?=?cmdTemp.CreateParameter("Return?Value",?3,?4,?4)
cmdTemp.Parameters.Append?tmpParam
Set?tmpParam?=?cmdTemp.CreateParameter("@BeginDate",?135,?1,?16,?riqi)?
'創建輸入參數對象
cmdTemp.Parameters.Append?tmpParam
rst.Open?cmdTemp,?,?1,?3????
'生成查詢結果
%>
這里調用的存儲過程為pd_test,這種是ADO中提供的標準方法,但存在一個問題,就是當在存儲過程中有兩個以上的SELECT語句,但從邏輯上又不可能同時執行的時候,ADO會提示你存儲過程中SELECT語句太多,解決方法是直接用ADO的CONNECTION對象的EXECUTE方法直接執行存儲過程,如下:
<%
Set?Dataconn?=?Server.CreateObject("ADODB.Connection")?
'建立連接對象
Dataconn.Open?"DSN=SinoTrans;SERVER=APP_SERVER;UID=sa;PWD=;APP=Microsoft(R)?Developer?Studio;WSID=APP_SERVER;Regional=Yes"
ss?=?"EXECUTE?dbo.pd_test?"?&?"'"?&?riqi1?&?"'"?
Set?rs?=?dataconn.Execute(ss)
%>????

上文是錯新技術頻道小編為大家帶來的ASP調用帶參數存儲過程的幾種方式,相信大家都學習的差不多了,希望了解以后對你學習有幫助作用哦。
?

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 五常市| 伊宁县| 司法| 赫章县| 新闻| 仙桃市| 民勤县| 江口县| 庆云县| 阿拉善右旗| 潢川县| 公主岭市| 石柱| 威信县| 南乐县| 浙江省| 丹棱县| 卓尼县| 扬州市| 苍梧县| 堆龙德庆县| 滦南县| 喀喇| 友谊县| 淳安县| 西藏| 治多县| 神农架林区| 新昌县| 温泉县| 大悟县| 聂荣县| 五台县| 鹤山市| 中山市| 元阳县| 商水县| 麻栗坡县| 古蔺县| 吉安县| 镇巴县|