CREATE PROCEDURE
建立預存程序,預存程序是儲存起來的可以接受和返回使用者提供的參數的 Transact-SQL 陳述式的集合。可以建立一個過程供永久使用,或在一個會話中臨時使用(局部暫存處理序),或在所有會話中臨時使用(全域暫存處理序)。也可以建立在 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 關鍵字的輸出參數可以是遊標預留位置。
n
表示最多可以指定 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 陳述式。但有一些限制。
n
是表示此過程可以包含多條 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 是將Null 字元串解釋為單個空格還是解釋為真正的Null 字元串,由相容層級設定控制。如果相容層級小於或等於 65,SQL Server 就將Null 字元串解釋為單個空格。如果相容層級等於 70,則 SQL Server 將Null 字元串解釋為空白字串。有關更多資訊,請參見 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 關鍵字。
說明 cursor 資料類型不能通過資料庫 API(例如 OLE DB、ODBC、ADO 和 DB-Library)綁定到應用程式變數上。因為必須先綁定 OUTPUT 參數,應用程式才可以執行預存程序,所以帶有 cursor OUTPUT 參數的預存程序不能通過資料庫 API 呼叫。只有將 cursor OUTPUT 變數賦值給 Transact-SQL 局部 cursor 變數時,才可以通過 Transact-SQL 批處理、預存程序或觸發器調用這些過程。
Cursor 輸出參數
在執行過程時,以下規則適用於 cursor 輸出參數:
對於順向資料指標,遊標的結果集中返回的行只是那些預存程序執行結束時處於或超出遊標位置的行,例如:
在過程中的名為 RS 的 100 行結果集上開啟一個非滾動遊標。
過程提取結果集 RS 的頭 5 行。
過程返回到其調用者。
返回到調用者的結果集 RS 由 RS 的第 6 到 100 行組成,調用者中的遊標處於 RS 的第一行之前。
對於順向資料指標,如果預存程序完成後,遊標位於第一行的前面,則整個結果集將返回給調用批處理、預存程序或觸發器。返回時,遊標將位於第一行的前面。
對於順向資料指標,如果預存程序完成後,遊標的位置超出最後一行的結尾,則為調用批處理、預存程序或觸發器返回空結果集。
說明 空結果集與空值不同。
對於可滾動遊標,在預存程序執行結束時,結果集中的所有行均會返回給調用批處理、預存程序或觸發器。返回時,遊標保留在過程中最後一次執行提取時的位置。
對於任意類型的遊標,如果遊標關閉,則將空值傳遞迴調用批處理、預存程序或觸發器。如果將遊標指派給一個參數,但該遊標從未開啟過,也會出現這種情況。
說明 關閉狀態只有在返回時才有影響。例如,可以在過程中關閉遊標,稍後再開啟遊標,然後將該遊標的結果集返回給調用批處理、預存程序或觸發器。
暫存預存程序
SQL Server 支援兩種暫存處理序:局部暫存處理序和全域暫存處理序。局部暫存處理序只能由建立該過程的串連使用。全域暫存處理序則可由所有串連使用。局部暫存處理序在當前會話結束時自動除去。全域暫存處理序在使用該過程的最後一個會話結束時除去。通常是在建立該過程的會話結束時。
暫存處理序用 # 和 ## 命名,可以由任何使用者建立。建立過程後,局部過程的所有者是唯一可以使用該過程的使用者。執行局部暫存處理序的許可權不能授予其他使用者。如果建立了全域暫存處理序,則所有使用者均可以訪問該過程,許可權不能顯式廢除。只有在 tempdb 資料庫中具有顯式 CREATE PROCEDURE 許可權的使用者,才可以在該資料庫中顯式建立暫存處理序(不使用編號符命名)。可以授予或廢除這些過程中的許可權。
說明 頻繁使用暫存預存程序會在 tempdb 中的系統資料表上產生爭用,從而對效能產生負面影響。建議使用 sp_executesql 代替。sp_executesql 不在系統資料表中儲存資料,因此可以避免這一問題。
自動執行預存程序
SQL Server 啟動時可以自動執行一個或多個預存程序。這些預存程序必須由系統管理員建立,並在 sysadmin 固定伺服器角色下作為後台過程執行。這些過程不能有任何輸入參數。
對啟動過程的數目沒有限制,但是要注意,每個啟動過程在執行時都會佔用一個串連。如果必須在啟動時執行多個過程,但不需要並存執行,則可以指定一個過程作為啟動過程,讓該程序呼叫其它過程。這樣就只佔用一個串連。
在啟動時恢複了最後一個資料庫後,即開始執行預存程序。若要跳過這些預存程序的執行,請將啟動參數指定為跟蹤標記 4022。如果以最低配置啟動 SQL Server(使用 -f 標記),則啟動預存程序也不會執行。有關更多資訊,請參見跟蹤標記。
若要建立啟動預存程序,必須作為 sysadmin 固定伺服器角色的成員登入,並在 master 資料庫中建立預存程序。
使用 sp_procoption 可以:
將現有預存程序指定為啟動過程。
停止在 SQL Server 啟動時執行過程。
查看 SQL Server 啟動時執行的所有過程的列表。
預存程序嵌套
預存程序可以嵌套,即一個預存程序可以調用另一個預存程序。在被調用過程開始執行時,嵌套級將增加,在被調用過程執行結束後,嵌套級將減少。如果超出最大的嵌套級,會使整個調用過程鏈失敗。可用 @@NESTLEVEL 函數返回當前的嵌套級。
若要估計編譯後的預存程序大小,請使用下列效能監控計數器。
效能監控器對象名 效能監控計數器名稱
SQLServer:緩衝區管理器 快取大小(頁面數)
SQLServer:快取管理器 快取命中率
快取頁
快取對象計數*
* 各種分類的快取對象均可以使用這些計數器,包括特殊 sql、準備 sql、過程、觸發器等。
有關更多資訊,請參見 SQL Server:Buffer Manager 對象和 SQL Server:Cache Manager 對象。
sql_statement 限制
除了 SET SHOWPLAN_TEXT 和 SET SHOWPLAN_ALL 之外(這兩個語句必須是批處理中僅有的語句),任何 SET 語句均可以在預存程序內部指定。所選擇的 SET 選項在預存程序執行過程中有效,之後恢複為原來的設定。
如果其他使用者要使用某個預存程序,那麼在該預存程序內部,一些語句使用的對象名必須使用對象所有者的名稱限定。這些語句包括:
ALTER TABLE
CREATE INDEX
CREATE TABLE
所有 DBCC 語句
DROP TABLE
DROP INDEX
TRUNCATE TABLE
UPDATE STATISTICS
許可權
CREATE PROCEDURE 的許可權預設授予 sysadmin 固定伺服器角色成員和 db_owner 和 db_ddladmin 固定資料庫角色成員。sysadmin 固定伺服器角色成員和 db_owner 固定資料庫角色成員可以將 CREATE PROCEDURE 許可權轉讓給其他使用者。執行預存程序的許可權授予過程的所有者,該所有者可以為其它資料庫使用者佈建執行許可權。
樣本
A. 使用帶有複雜 SELECT 語句的簡單過程
下面的預存程序從四個表的聯結中返回所有作者(提供了姓名)、出版的書籍以及出版社。該預存程序不使用任何參數。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'au_info_all' AND type = 'P')
DROP PROCEDURE au_info_all
GO
CREATE PROCEDURE au_info_all
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON t.title_id = ta.title_id INNER JOIN publishers p
ON t.pub_id = p.pub_id
GO
au_info_all 預存程序可以通過以下方法執行:
EXECUTE au_info_all
-- Or
EXEC au_info_all
如果該過程是批處理中的第一條語句,則可使用:
au_info_all
B. 使用帶有參數的簡單過程
下面的預存程序從四個表的聯結中只返回指定的作者(提供了姓名)、出版的書籍以及出版社。該預存程序接受與傳遞的參數精確匹配的值。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'au_info' AND type = 'P')
DROP PROCEDURE au_info
GO
USE pubs
GO
CREATE PROCEDURE au_info
@lastname varchar(40),
@firstname varchar(20)
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON t.title_id = ta.title_id INNER JOIN publishers p
ON t.pub_id = p.pub_id
WHERE au_fname = @firstname
AND au_lname = @lastname
GO
au_info 預存程序可以通過以下方法執行:
EXECUTE au_info 'Dull', 'Ann'
-- Or
EXECUTE au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
EXECUTE au_info @firstname = 'Ann', @lastname = 'Dull'
-- Or
EXEC au_info 'Dull', 'Ann'
-- Or
EXEC au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
EXEC au_info @firstname = 'Ann', @lastname = 'Dull'
如果該過程是批處理中的第一條語句,則可使用:
au_info 'Dull', 'Ann'
-- Or
au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
au_info @firstname = 'Ann', @lastname = 'Dull'
C. 使用帶有萬用字元參數的簡單過程
下面的預存程序從四個表的聯結中只返回指定的作者(提供了姓名)、出版的書籍以及出版社。該預存程序對傳遞的參數進行模式比對,如果沒有提供參數,則使用預設的預設值。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'au_info2' AND type = 'P')
DROP PROCEDURE au_info2
GO
USE pubs
GO
CREATE PROCEDURE au_info2
@lastname varchar(30) = 'D*',
@firstname varchar(18) = '*'
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON t.title_id = ta.title_id INNER JOIN publishers p
ON t.pub_id = p.pub_id
WHERE au_fname LIKE @firstname
AND au_lname LIKE @lastname
GO
au_info2 預存程序可以用多種組合執行。下面只列出了部分組合:
EXECUTE au_info2
-- Or
EXECUTE au_info2 'Wh*'
-- Or
EXECUTE au_info2 @firstname = 'A*'
-- Or
EXECUTE au_info2 '[CK]ars[OE]n'
-- Or
EXECUTE au_info2 'Hunter', 'Sheryl'
-- Or
EXECUTE au_info2 'H*', 'S*'
D. 使用 OUTPUT 參數
OUTPUT 參數允許外部過程、批處理或多條 Transact-SQL 陳述式訪問在過程執行期間設定的某個值。下面的樣本建立一個預存程序 (titles_sum),並使用一個可選的輸入參數和一個輸出參數。
首先,建立過程:
USE pubs
GO
IF EXISTS(SELECT name FROM sysobjects
WHERE name = 'titles_sum' AND type = 'P')
DROP PROCEDURE titles_sum
GO
USE pubs
GO
CREATE PROCEDURE titles_sum @@TITLE varchar(40) = '*', @@SUM money OUTPUT
AS
SELECT 'Title Name' = title
FROM titles
WHERE title LIKE @@TITLE
SELECT @@SUM = SUM(price)
FROM titles
WHERE title LIKE @@TITLE
GO
接下來,將該 OUTPUT 參數用於流程控制語言。
說明 OUTPUT 變數必須在建立表和使用該變數時都進行定義。
參數名和變數名不一定要匹配,不過資料類型和參數位置必須匹配(除非使用 @@SUM = variable 形式)。
DECLARE @@TOTALCOST money
EXECUTE titles_sum 'The*', @@TOTALCOST OUTPUT
IF @@TOTALCOST < 200
BEGIN
PRINT ' '
PRINT 'All of these titles can be purchased for less than $200.'
END
ELSE
SELECT 'The total cost of these titles is $'
+ RTRIM(CAST(@@TOTALCOST AS varchar(20)))
下面是結果集:
Title Name
------------------------------------------------------------------------
The Busy Executive's Database Guide
The Gourmet Microwave
The Psychology of Computer Cooking
(3 row(s) affected)
Warning, null value eliminated from aggregate.
All of these titles can be purchased for less than $200.
E. 使用 OUTPUT 遊標參數
OUTPUT 遊標參數用來將預存程序的局部遊標傳遞迴調用批處理、預存程序或觸發器。
首先,建立以下過程,在 titles 表上聲明並開啟一個遊標:
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'titles_cursor' and type = 'P')
DROP PROCEDURE titles_cursor
GO
CREATE PROCEDURE titles_cursor @titles_cursor CURSOR VARYING OUTPUT
AS
SET @titles_cursor = CURSOR
FORWARD_ONLY STATIC FOR
SELECT *
FROM titles
OPEN @titles_cursor
GO
接下來,執行一個批處理,聲明一個局部遊標變數,執行上述過程以將遊標賦值給局部變數,然後從該遊標提取行。
USE pubs
GO
DECLARE @MyCursor CURSOR
EXEC titles_cursor @titles_cursor = @MyCursor OUTPUT
WHILE (@@FETCH_STATUS = 0)
BEGIN
FETCH NEXT FROM @MyCursor
END
CLOSE @MyCursor
DEALLOCATE @MyCursor
GO
F. 使用 WITH RECOMPILE 選項
如果為過程提供的參數不是典型的參數,並且新的執行計畫不應快取或儲存在記憶體中,WITH RECOMPILE 子句會很有協助。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'titles_by_author' AND type = 'P')
DROP PROCEDURE titles_by_author
GO
CREATE PROCEDURE titles_by_author @@LNAME_PATTERN varchar(30) = '*'
WITH RECOMPILE
AS
SELECT RTRIM(au_fname) + ' ' + RTRIM(au_lname) AS 'Authors full name',
title AS Title
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON ta.title_id = t.title_id
WHERE au_lname LIKE @@LNAME_PATTERN
GO
G. 使用 WITH ENCRYPTION 選項
WITH ENCRYPTION 子句對使用者隱藏預存程序的文本。下例建立加密過程,使用 sp_helptext 系統預存程序擷取關於加密過程的資訊,然後嘗試直接從 syscomments 表中擷取關於該過程的資訊。
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'encrypt_this' AND type = 'P')
DROP PROCEDURE encrypt_this
GO
USE pubs
GO
CREATE PROCEDURE encrypt_this
WITH ENCRYPTION
AS
SELECT *
FROM authors
GO
EXEC sp_helptext encrypt_this
下面是結果集:
The object's comments have been encrypted.
接下來,選擇加密預存程序內容的標識號和文本。
SELECT c.id, c.text
FROM syscomments c INNER JOIN sysobjects o
ON c.id = o.id
WHERE o.name = 'encrypt_this'
下面是結果集:
說明 text 列的輸出顯示在單獨一行中。執行時,該資訊將與 id 列資訊出現在同一行中。
id text
---------- ------------------------------------------------------------
1413580074 ?????????????????????????????????e??????????????????????????????????????????????????????????????????????????
(1 row(s) affected)
H. 建立使用者定義的系統預存程序
下面的樣本建立一個過程,顯示表名以 emp 開頭的所有表及其對應的索引。如果沒有指定參數,該過程將返回表名以 sys 開頭的所有表(及索引)。
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'sp_showindexes' AND type = 'P')
DROP PROCEDURE sp_showindexes
GO
USE master
GO
CREATE PROCEDURE sp_showindexes
@@TABLE varchar(30) = 'sys*'
AS
SELECT o.name AS TABLE_NAME,
i.name AS INDEX_NAME,
indid AS INDEX_ID
FROM sysindexes i INNER JOIN sysobjects o
ON o.id = i.id
WHERE o.name LIKE @@TABLE
GO
USE pubs
EXEC sp_showindexes 'emp*'
GO
下面是結果集:
TABLE_NAME INDEX_NAME INDEX_ID
---------------- ---------------- ----------------
employee employee_ind 1
employee PK_emp_id 2
(2 row(s) affected)
I. 使用延遲名稱解析
下面的樣本顯示四個過程以及延遲名稱解析的各種可能使用方式。儘管引用的表或列在編譯時間不存在,但每個預存程序都可建立。
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'proc1' AND type = 'P')
DROP PROCEDURE proc1
GO
-- Creating a procedure on a nonexistent table.
USE pubs
GO
CREATE PROCEDURE proc1
AS
SELECT *
FROM does_not_exist
GO
-- Here is the statement to actually see the text of the procedure.
SELECT o.id, c.text
FROM sysobjects o INNER JOIN syscomments c
ON o.id = c.id
WHERE o.type = 'P' AND o.name = 'proc1'
GO
USE master
GO
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'proc2' AND type = 'P')
DROP PROCEDURE proc2
GO
-- Creating a procedure that attempts to retrieve information from a
-- nonexistent column in an existing table.
USE pubs
GO
CREATE PROCEDURE proc2
AS
DECLARE @middle_init char(1)
SET @middle_init = NULL
SELECT au_id, middle_initial = @middle_init
FROM authors
GO
-- Here is the statement to actually see the text of the procedure.
SELECT o.id, c.text
FROM sysobjects o INNER JOIN syscomments c
ON o.id = c.id
WHERE o.type = 'P' and o.name = 'proc2'
獲得有關預存程序的資訊
若要顯示用來建立過程的文本,請在過程所在的資料庫中執行 sp_helptext,並使用過程名作為參數。
說明 使用 ENCRYPTION 選項建立的預存程序不能使用 sp_helptext 查看。
若要顯示有關過程引用的對象的報表,請使用 sp_depends。
若要為過程重新命名,請使用 sp_rename。
執行預存程序
成功執行 CREATE PROCEDURE 語句後,過程名稱將儲存在 sysobjects 系統資料表中,而 CREATE PROCEDURE 語句的文本將儲存在 syscomments 中。第一次執行時,將編譯該過程以確定檢索資料的最佳訪問計劃。