亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > SQL Server > 正文

SQL Server存儲過程的基礎說明

2024-08-31 00:59:55
字體:
來源:轉載
供稿:網友
可以創建一個過程供永久使用,或在一個會話中臨時使用(局部臨時過程),或在所有會話中臨時使用(全局臨時過程)。
也可以創建在Microsoft SQL Server啟動時自動運行的存儲過程。
語法
CREATE PROC [ EDURE ] procedure_name [ ; number ]
[ { @parameter data_type }
[ VARYING ] [ = default ] [ OUTPUT ]
] [ ,...n ]
[ WITH
{ RECOMPILE | ENCRYPTION | RECOMPILE , ENCRYPTION } ]
[ FOR REPLICATION ]
AS sql_statement [ ...n ]
參數
procedure_name
新存儲過程的名稱。過程名必須符合標識符規則,且對于數據庫及其所有者必須唯一。有關更多信息,請參見使用標識符。
要創建局部臨時過程,可以在 procedure_name 前面加一個編號符 (#procedure_name),要創建全局臨時過程,可以在 procedure_name 前面加兩個編號符 (##procedure_name)。完整的名稱(包括 # 或 ##)不能超過 128 個字符。指定過程所有者的名稱是可選的。
;number
是可選的整數,用來對同名的過程分組,以便用一條 DROP PROCEDURE 語句即可將同組的過程一起除去。例如,名為 orders 的應用程序使用的過程可以命名為 orderproc;1、orderproc;2 等。DROP PROCEDURE orderproc 語句將除去整個組。如果名稱中包含定界標識符,則數字不應包含在標識符中,只應在 procedure_name 前后使用適當的定界符。
@parameter
過程中的參數。在 CREATE PROCEDURE 語句中可以聲明一個或多個參數。用戶必須在執行過程時提供每個所聲明參數的值(除非定義了該參數的默認值)。存儲過程最多可以有 2.100 個參數。
使用 @ 符號作為第一個字符來指定參數名稱。參數名稱必須符合標識符的規則。每個過程的參數僅用于該過程本身;相同的參數名稱可以用在其它過程中。默認情況下,參數只能代替常量,而不能用于代替表名、列名或其它數據庫對象的名稱。有關更多信息,請參見 EXECUTE。
data_type
參數的數據類型。所有數據類型(包括 text、ntext 和 image)均可以用作存儲過程的參數。不過,cursor 數據類型只能用于 OUTPUT 參數。如果指定的數據類型為 cursor,也必須同時指定 VARYING 和 OUTPUT 關鍵字。有關 SQL Server 提供的數據類型及其語法的更多信息,請參見數據類型。
說明 對于可以是 cursor 數據類型的輸出參數,沒有最大數目的限制。
VARYING
指定作為輸出參數支持的結果集(由存儲過程動態構造,內容可以變化)。僅適用于游標參數。
default
參數的默認值。如果定義了默認值,不必指定該參數的值即可執行過程。默認值必須是常量或 NULL。如果過程將對該參數使用 LIKE 關鍵字,那么默認值中可以包含通配符(%、_、[] 和 [^])。
OUTPUT
表明參數是返回參數。該選項的值可以返回給 EXEC[UTE]。使用 OUTPUT 參數可將信息返回給調用過程。Text、ntext 和 image 參數可用作 OUTPUT 參數。使用 OUTPUT 關鍵字的輸出參數可以是游標占位符。

表示最多可以指定 2.100 個參數的占位符。
{RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}
RECOMPILE 表明 SQL Server 不會緩存該過程的計劃,該過程將在運行時重新編譯。在使用非典型值或臨時值而不希望覆蓋緩存在內存中的執行計劃時,請使用 RECOMPILE 選項。
ENCRYPTION 表示 SQL Server 加密 syscomments 表中包含 CREATE PROCEDURE 語句文本的條目。使用 ENCRYPTION 可防止將過程作為 SQL Server 復制的一部分發布。
說明 在升級過程中,SQL Server 利用存儲在 syscomments 中的加密注釋來重新創建加密過程。
FOR REPLICATION
指定不能在訂閱服務器上執行為復制創建的存儲過程。.使用 FOR REPLICATION 選項創建的存儲過程可用作存儲過程篩選,且只能在復制過程中執行。本選項不能和 WITH RECOMPILE 選項一起使用。
AS
指定過程要執行的操作。
sql_statement
過程中要包含的任意數目和類型的 Transact-SQL 語句。但有一些限制。

是表示此過程可以包含多條 Transact-SQL 語句的占位符。
注釋
存儲過程的最大大小為 128 MB。
用戶定義的存儲過程只能在當前數據庫中創建(臨時過程除外,臨時過程總是在 tempdb 中創建)。在單個批處理中,CREATE PROCEDURE 語句不能與其它 Transact-SQL 語句組合使用。
默認情況下,參數可為空。如果傳遞 NULL 參數值并且該參數在 CREATE 或 ALTER TABLE 語句中使用,而該語句中引用的列又不允許使用 NULL,則 SQL Server 會產生一條錯誤信息。為了防止向不允許使用 NULL 的列傳遞 NULL 參數值,應向過程中添加編程邏輯或為該列使用默認值(使用 CREATE 或 ALTER TABLE 的 DEFAULT 關鍵字)。
建議在存儲過程的任何 CREATE TABLE 或 ALTER TABLE 語句中都為每列顯式指定 NULL 或 NOT NULL,例如在創建臨時表時。ANSI_DFLT_ON 和 ANSI_DFLT_OFF 選項控制 SQL Server 為列指派 NULL 或 NOT NULL 特性的方式(如果在 CREATE TABLE 或 ALTER TABLE 語句中沒有指定的話)。如果某個連接執行的存儲過程對這些選項的設置與創建該過程的連接的設置不同,則為第二個連接創建的表列可能會有不同的為空性,并且表現出不同的行為方式。如果為每個列顯式聲明了 NULL 或 NOT NULL,那么將對所有執行該存儲過程的連接使用相同的為空性創建臨時表。
在創建或更改存儲過程時,SQL Server 將保存 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 的設置。執行存儲過程時,將使用這些原始設置。因此,所有客戶端會話的 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 設置在執行存儲過程時都將被忽略。在存儲過程中出現的 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 語句不影響存儲過程的功能。
其它 SET 選項(例如 SET ARITHABORT、SET ANSI_WARNINGS 或 SET ANSI_PADDINGS)在創建或更改存儲過程時不保存。如果存儲過程的邏輯取決于特定的設置,應在過程開頭添加一條 SET 語句,以確保設置正確。從存儲過程中執行 SET 語句時,該設置只在存儲過程完成之前有效。之后,設置將恢復為調用存儲過程時的值。這使個別的客戶端可以設置所需的選項,而不會影響存儲過程的邏輯。
說明 SQL Server 是將空字符串解釋為單個空格還是解釋為真正的空字符串,由兼容級別設置控制。如果兼容級別小于或等于 65,SQL Server 就將空字符串解釋為單個空格。如果兼容級別等于 70,則 SQL Server 將空字符串解釋為空字符串。有關更多信息,請參見 sp_dbcmptlevel。
獲得有關存儲過程的信息
若要顯示用來創建過程的文本,請在過程所在的數據庫中執行 sp_helptext,并使用過程名作為參數。
說明 使用 ENCRYPTION 選項創建的存儲過程不能使用 sp_helptext 查看。
若要顯示有關過程引用的對象的報表,請使用 sp_depends。
若要為過程重命名,請使用 sp_rename。
引用對象
SQL Server 允許創建的存儲過程引用尚不存在的對象。在創建時,只進行語法檢查。執行時,如果高速緩存中尚無有效的計劃,則編譯存儲過程以生成執行計劃。只有在編譯過程中才解析存儲過程中引用的所有對象。因此,如果語法正確的存儲過程引用了不存在的對象,則仍可以成功創建,但在運行時將失敗,因為所引用的對象不存在。有關更多信息,請參見延遲名稱解析和編譯。
延遲名稱解析和兼容級別
SQL Server 允許 Transact-SQL 存儲過程在創建時引用不存在的表。這種能力稱為延遲名稱解析。不過,如果 Transact-SQL 存儲過程引用了該存儲過程中定義的表,而兼容級別設置(通過執行 sp_dbcmptlevel 來設置)為 65,則在創建時會發出警告信息。而如果在運行時所引用的表不存在,將返回錯誤信息。有關更多信息,請參見 sp_dbcmptlevel 和延遲名稱解析和編譯。
執行存儲過程
成功執行 CREATE PROCEDURE 語句后,過程名稱將存儲在 sysobjects 系統表中,而 CREATE PROCEDURE 語句的文本將存儲在 syscomments 中。第一次執行時,將編譯該過程以確定檢索數據的最佳訪問計劃。
使用 cursor 數據類型的參數
存儲過程只能將 cursor 數據類型用于 OUTPUT 參數。如果為某個參數指定了 cursor 數據類型,也必須指定 VARYING 和 OUTPUT 參數。如果為某個參數指定了 VARYING 關鍵字,則數據類型必須是 cursor,并且必須指定 OUTPUT 關鍵字。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩精品久久亚洲区| 亚洲第一天堂无码专区| 久久久久久九九九| 久久99久国产精品黄毛片入口| 国外成人免费在线播放| 3344国产精品免费看| 国产成人一区二区在线| 久久精品色欧美aⅴ一区二区| 亚洲第一在线视频| 欧美俄罗斯乱妇| 欧美黄色小视频| 欧美激情欧美激情| 欧美影院久久久| 国产精品久久久久久久久借妻| 奇米一区二区三区四区久久| 精品在线欧美视频| 国内揄拍国内精品少妇国语| 欧美激情亚洲国产| 国产精品久久久999| 国产精品久久久久久五月尺| 亚洲国产精品专区久久| 亚洲成人激情在线观看| 亚洲系列中文字幕| 亚洲a∨日韩av高清在线观看| 一区二区三区 在线观看视| 日本不卡视频在线播放| 国产成人一区二区三区小说| 亚洲网站在线观看| 久久久久久亚洲| 精品久久久久久久久久久久久久| 亚洲国产一区二区三区在线观看| 久久91精品国产91久久久| 亚洲国产成人爱av在线播放| 夜夜嗨av一区二区三区四区| 久久精品亚洲94久久精品| 成人春色激情网| 不用播放器成人网| 久久久久久久国产| 久久夜精品va视频免费观看| 97热精品视频官网| 精品国产乱码久久久久久婷婷| 亚洲久久久久久久久久久| 亚洲第一福利网站| 97超级碰在线看视频免费在线看| 欧美激情在线一区| 亚洲精品黄网在线观看| 亚洲国产精品久久久久秋霞蜜臀| 亚洲国产99精品国自产| 欧美电影免费在线观看| 成人午夜激情免费视频| 国产精品91久久久久久| 欧美视频在线观看免费网址| 亚洲欧洲在线看| 国产偷国产偷亚洲清高网站| 精品无人国产偷自产在线| 久久这里只有精品99| 久久噜噜噜精品国产亚洲综合| 亚洲精品之草原avav久久| 亚洲视频999| 国产美女高潮久久白浆| 福利一区视频在线观看| 一区二区欧美在线| 国产精品极品美女在线观看免费| 午夜精品美女自拍福到在线| 欧美在线激情网| 国产精品网站大全| 成人精品在线视频| 国产精品第3页| 日韩风俗一区 二区| 欧美激情在线一区| 久久久国产精品x99av| 欧美成人免费观看| 日本中文字幕成人| 91精品91久久久久久| 91在线观看免费高清| 正在播放欧美一区| 亚洲韩国日本中文字幕| 欧洲亚洲女同hd| 777国产偷窥盗摄精品视频| 午夜免费在线观看精品视频| 久久久久久久影视| 精品成人久久av| 国产啪精品视频| 亚洲欧美自拍一区| 欧美大成色www永久网站婷| 青青a在线精品免费观看| 日韩午夜在线视频| 国产一区二区欧美日韩| 日韩av在线精品| 欧美大片在线看免费观看| 国产一区二区日韩| 亚洲97在线观看| 亚洲美女视频网站| 97精品一区二区三区| 亚洲午夜未满十八勿入免费观看全集| 国产a∨精品一区二区三区不卡| 国产日韩在线观看av| 欧美成在线视频| 美女福利精品视频| 久久精品国产2020观看福利| 日韩视频中文字幕| 国产精品h片在线播放| 7m第一福利500精品视频| 日韩av电影在线免费播放| 亚洲开心激情网| 亚洲欧美日韩一区在线| 高清亚洲成在人网站天堂| 久久久久久久国产| 国产精品高清免费在线观看| 亚洲欧美综合精品久久成人| 中文字幕亚洲欧美日韩在线不卡| 日韩欧美a级成人黄色| 国产精品影院在线观看| 日韩中文综合网| 中文字幕久久亚洲| 懂色aⅴ精品一区二区三区蜜月| 日韩欧美亚洲范冰冰与中字| 成人网在线免费看| 久久91亚洲精品中文字幕奶水| 亚洲国产精彩中文乱码av在线播放| 欧美成人午夜免费视在线看片| 国产日韩综合一区二区性色av| 亚洲a区在线视频| 欧美巨猛xxxx猛交黑人97人| 成人性生交大片免费观看嘿嘿视频| 精品久久久av| 久久久精品国产亚洲| 国产成人极品视频| 亚洲午夜国产成人av电影男同| 精品国产一区久久久| 精品久久久久久久大神国产| 精品久久久久人成| 欧美激情一二区| 欧美日韩成人网| 欧美国产日本高清在线| 久久夜色精品亚洲噜噜国产mv| 午夜免费在线观看精品视频| 国产欧美一区二区三区久久人妖| 国产欧美一区二区三区在线看| 亚洲成色777777女色窝| 高清一区二区三区四区五区| 精品av在线播放| 揄拍成人国产精品视频| 欧美大全免费观看电视剧大泉洋| 91精品国产综合久久香蕉的用户体验| 欧美性理论片在线观看片免费| 欧美另类第一页| 国产精品一区二区电影| 国产成人极品视频| 欧美精品国产精品日韩精品| 成人免费淫片视频软件| 岛国视频午夜一区免费在线观看| 亚洲一区二区中文字幕| 国产精品激情av电影在线观看| 国产欧美va欧美va香蕉在| 日韩欧中文字幕| 欧美美女15p| 在线亚洲国产精品网| 欧美另类极品videosbestfree| 97精品久久久中文字幕免费| 成人久久精品视频| 日韩精品极品在线观看| 91亚洲va在线va天堂va国| 插插插亚洲综合网|