校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > sql存儲過程的使用和介紹

sql存儲過程的使用和介紹

熱門標簽:承德地圖標注公司名需要花錢嗎 北京400電話辦理多少錢 電銷外呼系統軟件功能 榕城市地圖標注 慶陽地圖標注 咸陽電腦外呼系統運營商 怎么給高德做地圖標注 美團地圖標注商戶認證注冊 浙江穩定外呼系統供應商

sql server存儲過程語法

    定義總是很抽象。存儲過程其實就是能完成一定操作的一組SQL語句,只不過這組語句是放在數據庫中的(這里我們只談SQL Server)。如果我們通過創建存儲過程以及在ASP中調用存儲過程,就可以避免將SQL語句同ASP代碼混雜在一起。這樣做的好處至少有三個:
    第一、大大提高效率。存儲過程本身的執行速度非???,而且,調用存儲過程可以大大減少同數據庫的交互次數。
    第二、提高安全性。假如將SQL語句混合在ASP代碼中,一旦代碼失密,同時也就意味著庫結構失密。
    第三、有利于SQL語句的重用。

    在ASP中,一般通過command對象調用存儲過程,根據不同情況,本文也介紹其它調用方法。為了方便說明,根據存儲過程的輸入輸出,作以下簡單分類:
    1. 只返回單一記錄集的存儲過程
    假設有以下存儲過程(本文的目的不在于講述T-SQL語法,所以存儲過程只給出代碼,不作說明):

復制代碼 代碼如下:

    /*SP1*/
    CREATE PROCEDURE dbo.getUserList
    as
    set nocount on
    begin
       select * from dbo.[userinfo]
    end
    go

    以上存儲過程取得userinfo表中的所有記錄,返回一個記錄集。通過command對象調用該存儲過程的ASP代碼如下:

    '**通過Command對象調用存儲過程**
復制代碼 代碼如下:

    DIM MyComm,MyRst
    Set MyComm = Server.CreateObject("ADODB.Command")
    MyComm.ActiveConnection = MyConStr          'MyConStr是數據庫連接字串
    MyComm.CommandText      = "getUserList"     '指定存儲過程名
    MyComm.CommandType      = 4                 '表明這是一個存儲過程
    MyComm.Prepared         = true              '要求將SQL命令先行編譯
    Set MyRst = MyComm.Execute
    Set MyComm = Nothing

    存儲過程取得的記錄集賦給MyRst,接下來,可以對MyRst進行操作。
    在以上代碼中,CommandType屬性表明請求的類型,取值及說明如下:
      -1   表明CommandText參數的類型無法確定

     1    表明CommandText是一般的命令類型
      2    表明CommandText參數是一個存在的表名稱
      4    表明CommandText參數是一個存儲過程的名稱

    還可以通過Connection對象或Recordset對象調用存儲過程,方法分別如下:

    '**通過Connection對象調用存儲過程**

復制代碼 代碼如下:

    DIM MyConn,MyRst
    Set MyConn = Server.CreateObject("ADODB.Connection")
    MyConn.open MyConStr                            'MyConStr是數據庫連接字串
    Set MyRst  = MyConn.Execute("getUserList",0,4)  '最后一個參斷含義同CommandType
    Set MyConn = Nothing

    '**通過Recordset對象調用存儲過程**
    DIM MyRst
    Set MyRst = Server.CreateObject("ADODB.Recordset")
    MyRst.open "getUserList",MyConStr,0,1,4
    'MyConStr是數據庫連接字串,最后一個參斷含義與CommandType相同



    2. 沒有輸入輸出的存儲過程
    請看以下存儲過程:
復制代碼 代碼如下:

    /*SP2*/
    CREATE PROCEDURE dbo.delUserAll
    as
    set nocount on
    begin
       delete from dbo.[userinfo]
    end
    go

    該存儲過程刪去userinfo表中的所有記錄,沒有任何輸入及輸出,調用方法與上面講過的基本相同,只是不用取得記錄集:

    '**通過Command對象調用存儲過程**

復制代碼 代碼如下:

    DIM MyComm
    Set MyComm = Server.CreateObject("ADODB.Command")
    MyComm.ActiveConnection = MyConStr          'MyConStr是數據庫連接字串
    MyComm.CommandText      = "delUserAll"      '指定存儲過程名
    MyComm.CommandType      = 4                 '表明這是一個存儲過程
    MyComm.Prepared         = true              '要求將SQL命令先行編譯
    MyComm.Execute                              '此處不必再取得記錄集

    Set MyComm = Nothing


    當然也可通過Connection對象或Recordset對象調用此類存儲過程,不過建立Recordset對象是為了取得記錄集,在沒有返回記錄集的情況下,還是利用Command對象吧。


    3. 有返回值的存儲過程
    在進行類似SP2的操作時,應充分利用SQL Server強大的事務處理功能,以維護數據的一致性。并且,我們可能需要存儲過程返回執行情況,為此,將SP2修改如下:

復制代碼 代碼如下:

    /*SP3*/
    CREATE PROCEDURE dbo.delUserAll
    as
    set nocount on
    begin
       BEGIN TRANSACTION
       delete from dbo.[userinfo]
       IF @@error=0
          begin
             COMMIT TRANSACTION
             return 1
          end
       ELSE
          begin
             ROLLBACK TRANSACTION
             return 0
          end       
       return
    end
    go

    以上存儲過程,在delete順利執行時,返回1,否則返回0,并進行回滾操作。為了在ASP中取得返回值,需要利用Parameters集合來聲明參數:
復制代碼 代碼如下:

    '**調用帶有返回值的存儲過程并取得返回值**
    DIM MyComm,MyPara
    Set MyComm = Server.CreateObject("ADODB.Command")
    MyComm.ActiveConnection = MyConStr          'MyConStr是數據庫連接字串
    MyComm.CommandText      = "delUserAll"      '指定存儲過程名
    MyComm.CommandType      = 4                 '表明這是一個存儲過程
    MyComm.Prepared         = true              '要求將SQL命令先行編譯
    '聲明返回值
    Set Mypara = MyComm.CreateParameter("RETURN",2,4)

    MyComm.Parameters.Append MyPara
    MyComm.Execute
    '取得返回值
    DIM retValue
    retValue = MyComm(0)    '或retValue = MyComm.Parameters(0)
    Set MyComm = Nothing

  
    在MyComm.CreateParameter("RETURN",2,4)中,各參數的含義如下:
    第一個參數("RETURE")為參數名。參數名可以任意設定,但一般應與存儲過程中聲明的參數名相同。此處是返回值,我習慣上設為"RETURE";
    第二個參數(2),表明該參數的數據類型,具體的類型代碼請參閱ADO參考,以下給出常用的類型代碼:
    adBigInt: 20 ;
    adBinary : 128 ;
    adBoolean: 11 ;
    adChar: 129 ;
    adDBTimeStamp: 135 ;
    adEmpty: 0 ;
    adInteger: 3 ;
    adSmallInt: 2 ;
    adTinyInt: 16 ;
    adVarChar: 200 ;
    對于返回值,只能取整形,且-1到-99為保留值;
    第三個參數(4),表明參數的性質,此處4表明這是一個返回值。此參數取值的說明如下:
    0 : 類型無法確定; 1: 輸入參數;2: 輸入參數;3:輸入或輸出參數;4: 返回值

    以上給出的ASP代碼,應該說是完整的代碼,也即最復雜的代碼,其實
復制代碼 代碼如下:

    Set Mypara = MyComm.CreateParameter("RETURN",2,4)
    MyComm.Parameters.Append MyPara
 
     
    可以簡化為
復制代碼 代碼如下:

    MyComm.Parameters.Append MyComm.CreateParameter("RETURN",2,4)

    甚至還可以繼續簡化,稍后會做說明。
    對于帶參數的存儲過程,只能使用Command對象調用(也有資料說可通過Connection對象或Recordset對象調用,但我沒有試成過)。


    4. 有輸入參數和輸出參數的存儲過程
    返回值其實是一種特殊的輸出參數。在大多數情況下,我們用到的是同時有輸入及輸出參數的存儲過程,比如我們想取得用戶信息表中,某ID用戶的用戶名,這時候,有一個輸入參數----用戶ID,和一個輸出參數----用戶名。實現這一功能的存儲過程如下:

復制代碼 代碼如下:

    /*SP4*/
    CREATE PROCEDURE dbo.getUserName
       @UserID int,
       @UserName varchar(40) output
    as
    set nocount on
    begin
       if @UserID is null return
       select @UserName=username
           from dbo.[userinfo]

04017PIXTEL_MMI_EBOOK_2005>17                                                          /PIXTEL_MMI_EBOOK_2005>

標簽:重慶 呼和浩特 新鄉 上海 拉薩 江蘇 昭通 貴州

巨人網絡通訊聲明:本文標題《sql存儲過程的使用和介紹》,本文關鍵詞  sql,存儲,過程,的,使用,和,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《sql存儲過程的使用和介紹》相關的同類信息!
  • 本頁收集關于sql存儲過程的使用和介紹的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    久久精品国产一区二区三| 日本一区二区成人在线| 色8久久人人97超碰香蕉987| 成人天堂资源www在线| 精品一区二区在线视频| 狠狠色综合播放一区二区| 久久精品国产一区二区三| 国产一区二区不卡老阿姨| 国产成人免费视| 99免费精品在线| 色婷婷综合久久| 欧美影院午夜播放| 在线播放欧美女士性生活| 日韩丝袜情趣美女图片| 久久伊人蜜桃av一区二区| 日韩女优视频免费观看| 国产欧美日韩亚州综合| 中文字幕在线视频一区| 亚洲午夜羞羞片| 另类小说视频一区二区| 国产二区国产一区在线观看| www.欧美色图| 欧美剧情片在线观看| 亚洲精品在线观| 亚洲欧美一区二区三区国产精品| 亚洲电影一区二区| 激情六月婷婷久久| 99热国产精品| 日韩欧美一区电影| 国产精品美女一区二区| 午夜视频在线观看一区| 国产一区美女在线| 色婷婷久久99综合精品jk白丝| 欧美三级韩国三级日本三斤 | 99国产欧美另类久久久精品| 色88888久久久久久影院按摩| 欧美日本免费一区二区三区| 26uuu欧美| 亚洲国产成人va在线观看天堂| 美国三级日本三级久久99 | 一级做a爱片久久| 理论片日本一区| 色欧美乱欧美15图片| 欧美一二三四在线| 亚洲欧美一区二区不卡| 九九精品一区二区| 欧美亚洲免费在线一区| 久久久精品中文字幕麻豆发布| 久久国产精品免费| 91天堂素人约啪| 精品国产91九色蝌蚪| 亚洲一区二区黄色| 99久久久无码国产精品| 久久久久久久久久久电影| 亚洲高清免费一级二级三级| 成人av集中营| 久久久影视传媒| 久久超碰97人人做人人爱| 欧美在线免费视屏| 亚洲日本免费电影| 成人激情校园春色| 国产亚洲一区二区在线观看| 日韩av一二三| 777亚洲妇女| 亚洲网友自拍偷拍| 色婷婷综合五月| 亚洲美女屁股眼交3| 99久久综合国产精品| 国产农村妇女毛片精品久久麻豆| 精品一区二区三区香蕉蜜桃 | 色94色欧美sute亚洲线路一ni| 国产精品女同一区二区三区| 国产成人亚洲精品狼色在线| 精品电影一区二区三区 | 国产91丝袜在线观看| 精品日韩在线一区| 精品一区二区久久| 欧美成人a视频| 国产乱子轮精品视频| 日韩视频在线一区二区| 精品一区二区三区久久| 久久欧美一区二区| 成人免费看片app下载| 国产精品电影一区二区| 97超碰欧美中文字幕| 亚洲一区二区精品视频| 91精品在线麻豆| 久久91精品国产91久久小草| 国产日韩欧美高清| 91亚洲国产成人精品一区二三| 亚洲另类中文字| 欧美日韩一级大片网址| 日本v片在线高清不卡在线观看| 精品日韩成人av| 成人免费av网站| 亚洲综合网站在线观看| 欧美成人在线直播| 成人免费黄色在线| 亚洲国产精品尤物yw在线观看| 5月丁香婷婷综合| 国产成人在线视频网站| 亚洲精品日产精品乱码不卡| 欧美放荡的少妇| 国产69精品久久久久777| 尤物在线观看一区| 欧美一区2区视频在线观看| 国产福利一区在线| 亚洲精品成人少妇| 精品人在线二区三区| 波多野结衣欧美| 天天操天天综合网| 欧美激情中文字幕一区二区| 欧美视频完全免费看| 国产成人av电影免费在线观看| 一区二区高清视频在线观看| 精品三级在线看| 欧美撒尿777hd撒尿| 国产乱码精品一品二品| 亚洲成a人v欧美综合天堂下载 | 国产欧美日韩在线视频| 在线播放视频一区| 色综合一区二区| 一区二区三区四区在线播放| 欧美精品九九99久久| 国产69精品久久久久777| 日韩电影在线免费看| 亚洲激情图片qvod| 国产精品久久久一区麻豆最新章节| 欧美巨大另类极品videosbest| 91小视频免费观看| 国产精品乡下勾搭老头1| 麻豆精品蜜桃视频网站| 亚洲a一区二区| 一区二区三区成人| 中文字幕一区二| 中文字幕乱码日本亚洲一区二区| 日韩午夜精品电影| 91精品国产综合久久久久久久久久| 色悠悠久久综合| 99视频一区二区| 懂色av中文一区二区三区| 国产一区二区精品久久99| 久久精品国产精品亚洲综合| 天堂久久久久va久久久久| 亚洲成人你懂的| 亚洲最新视频在线观看| 一区二区三区在线看| 亚洲精品免费看| 一区二区在线观看免费| 亚洲男人电影天堂| 中文字幕一区二区不卡| 综合婷婷亚洲小说| 亚洲乱码中文字幕| 亚洲精选视频免费看| 伊人色综合久久天天| 亚洲欧美一区二区三区国产精品| 综合激情网...| 亚洲乱码国产乱码精品精小说 | 蜜臀av性久久久久蜜臀aⅴ流畅| 亚洲成a人在线观看| 日韩国产欧美在线播放| 免费在线观看精品| 一本色道**综合亚洲精品蜜桃冫| 白白色 亚洲乱淫| 91小视频免费观看| 欧美日本一道本| 精品欧美乱码久久久久久| 精品国产乱码久久| 国产亚洲精品资源在线26u| 国产精品久久综合| 亚洲午夜av在线| 久久99精品久久久久久久久久久久| 久久99国产精品久久99| 成人精品国产免费网站| 91久久一区二区| 日韩一级完整毛片| 欧美国产精品专区| 一区二区三区在线视频免费观看| 视频在线观看91| 懂色av一区二区三区蜜臀 | 欧美成人艳星乳罩| 国产欧美一区视频| 一区二区三区蜜桃| 免费观看在线综合| 福利电影一区二区三区| 在线中文字幕不卡| 精品福利一区二区三区| 亚洲欧洲成人自拍| 五月天视频一区| 国产99久久久国产精品潘金| 欧美在线视频你懂得| 久久夜色精品国产噜噜av| 一区二区三区免费在线观看| 国产在线精品免费| 91国产视频在线观看| 精品第一国产综合精品aⅴ| 亚洲精品免费在线播放| 国产精一区二区三区| 欧美另类高清zo欧美| 中文字幕一区二区三|