日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

asp調(diào)用存儲過程

系統(tǒng) 1937 0
1.調(diào)用存儲過程的一般方法
先假設(shè)在sql server中有一存儲過程dt_users:
CREATE PROCEDURE [dbo].[dt_users]
AS
select * from users
return
GO
第一種方法是不利用command對象,直接用recordset對象
set rs=server.createobject("adodb.recordset")
sql="exec dt_users"
rs.open sql,conn,1,1 這樣就可
第二種方法是利用command對象
set comm=server.createobject("adodb.command")
comm.commantype=4
set comm.activeconnection=conn
comm.commandtext="dbo.dt_users"
set rs=server.createobject("adodb.recordset")
rs.open comm,,1,1
2.給存儲過程傳遞參數(shù)
如果存儲過程中不用參數(shù),而是單一的sql語句,還顯示不出調(diào)用存儲過程的優(yōu)勢!
比如說一bbs的查詢,可以按作者和主題查詢!則可以建立存儲過程如下:
參數(shù)keyword為關(guān)鍵字,choose是選擇查詢的方法。
CREATE PROCEDURE [dbo].[dt_bbs]
@keyword varchar(20)=null,
@choose int=null
as
if @choose=1
select * from bbs where name like @keyword
else
select * from bbs where subject like @keyword
return
go
這樣我們調(diào)用存儲過程時只需將參數(shù)傳遞過去就行了,而省去在asp中來寫一段程序
用第一種方法:
set rs=server.createobject("adodb.recordset")
sql="exec dt_bbs '"&keyword&"',"&choose&""
rs.open sql,conn,1,1
用第二種方法:
set comm=server.createobject("adodb.command")
comm.commantype=4
comm.Parameters.append comm.CreateParameter("@keyword",adChar,adParamInput,50,keyword)
comm.Parameters.append comm.CreateParameter("@keyword",adInteger,adParamInput,,choose)
set comm.activeconnection=conn
comm.commandtext="dbo.dt_bbs"
set rs=server.createobject("adodb.recordset")
rs.CursorType=3
rs.open comm,,1,1

3.進一步討論
比較上面我所說的兩種在asp種調(diào)用存儲過程的方法,
第一種方法需要對象少,但recordset對象支持的屬性少了很多,比如說:rs.recordcount,rs.pagecount,rs.absolutepage這些屬性
都不支持,所以用第一種方法就有局限,比如說要分頁顯示紀錄時,就必須要用到第二種方法。
我們用sql server中的存儲過程目的是為了加快速度,但一個存儲過程中sql語句有很多時,它的優(yōu)勢特別明顯。如果sql語句不是很多,
而我們用第二種方法就必須多創(chuàng)建一個command對象,可能還會減慢速度!所以我們要均衡各方面的利益來使用存儲過程。
不過我覺得不過速度怎樣,使用存儲過程可以使程序更加模塊化,便于修改,和調(diào)試(可以直接在sql server下調(diào)試,而不用在ie下看asp
的結(jié)果)。

asp調(diào)用存儲過程


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 西林县| 楚雄市| 鄯善县| 若羌县| 东丰县| 乐安县| 舞钢市| 当雄县| 二连浩特市| 东乡县| 敦化市| 阳高县| 扎赉特旗| 泸州市| 旬邑县| 五常市| 忻州市| 金塔县| 延寿县| 深圳市| 志丹县| 桐乡市| 建阳市| 贺州市| 淅川县| 萨迦县| 洪江市| 雅安市| 长阳| 临猗县| 通渭县| 东乡族自治县| 黎平县| 于田县| 乐山市| 宜春市| 平度市| 喀喇| 宜丰县| 临夏市| 遂平县|