解讀SQL存儲過程入門級教程(4)_Mssql數據庫教程

      編輯Tag賺U幣
      教程Tag:暫無Tag,歡迎添加,賺取U幣!

      推薦:按指定排列順序獲取數據的sql語句
      測試table create table table1 (id int,name char) insert into table1 select 1,'q' union all select 2,'r' union all select 3,'3' union all select 4,'5' 要求按指定的id順序(比如2,1,4,3)排列獲取table1的數據 方法1: 使用union all,但是有256條數據的



      說明 SQL Server 是將空字符串解釋為單個空格還是解釋為真正的空字符串,由兼容級別設置控制。
      如果兼容級別小于或等于 65,SQL Server 就將空字符串解釋為單個空格。
      如果兼容級別等于 70,則 SQL Server 將空字符串解釋為空字符串。
      獲得有關存儲過程的信息
      若要顯示用來創建過程的文本,請在過程所在的數據庫中執行 sp_helptext,并使用過程名作為參數。 


      說明 使用 ENCRYPTION 選項創建的存儲過程不能使用 sp_helptext 查看。


      若要顯示有關過程引用的對象的報表,請使用 sp_depends。 

      若要為過程重命名,請使用 sp_rename。 


      引用對象

      SQL Server 允許創建的存儲過程引用尚不存在的對象。在創建時,只進行語法檢查。執行時,如果高速緩存中尚無有效的計劃,則編譯存儲過程以生成執行計劃。只有在編譯過 程中才解析存儲過程中引用的所有對象。因此,如果語法正確的存儲過程引用了不存在的對象,則仍可以成功創建,但在運行時將失敗,因為所引用的對象不存在。
      延遲名稱解析和兼容級別
      SQL Server 允許 Transact-SQL 存儲過程在創建時引用不存在的表。這種能力稱為延遲名稱解析。不過,如果 Transact-SQL 存儲過程引用了該存儲過程中定義的表,而兼容級別設置(通過執行 sp_dbcmptlevel 來設置)為 65,則在創建時會發出警告信息。而如果在運行時所引用的表不存在,將返回錯誤信息。

      執行存儲過程

      成功執行 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語句(2)
      向表中添加一個新記錄,你要使用SQLINSERT語句。 這里有一個如何使用這種語句的例子: INSERTmytable(mycolumn)VALUES(‘somedata’) 這個語句把字符串’somedata’插入表mytable的mycolumn字段中。將要被插入數據的字段的名字在第一個括號中指定,實際的數

      來源:模板無憂//所屬分類:Mssql數據庫教程/更新時間:2010-04-06
      相關Mssql數據庫教程