標籤:style   blog   io   ar   color   os   使用   sp   for   
1. 遊標簡介
  遊標是一種處理資料的方法,主要用於預存程序、觸發器和Transact-SQL指令碼中。SELECT語句返回的是一個結果集,遊標能夠從包含多條資料記錄的結果集中每次提取一條記錄。
  遊標的特點:
  ◊ 允許對由SELECT查詢語句返回的行集中的每一行執行相同或者不同的操作,而不是對整個集合執行同一個操作。
  ◊ 提供對基於遊標位置的表中的行進行刪除和更新。
2. 遊標的基本操作
2.1 聲明遊標
  聲明遊標文法:
ISO SyntaxDECLARE cursor_name [ INSENSITIVE ] [ SCROLL ] CURSOR      FOR select_statement      [ FOR { READ ONLY | UPDATE [ OF column_name [ ,...n ] ] } ][;]Transact-SQL Extended SyntaxDECLARE cursor_name CURSOR [ LOCAL | GLOBAL ]      [ FORWARD_ONLY | SCROLL ]      [ STATIC | KEYSET | DYNAMIC | FAST_FORWARD ]      [ READ_ONLY | SCROLL_LOCKS | OPTIMISTIC ]      [ TYPE_WARNING ]      FOR select_statement      [ FOR UPDATE [ OF column_name [ ,...n ] ] ][;]
2.2 開啟遊標
  在使用遊標之前,必須開啟遊標。開啟遊標的文法格式:
OPEN { { [ GLOBAL ] cursor_name } | cursor_variable_name }
2.3 讀取遊標中的資料
  開啟遊標之後,可以讀取遊標中的資料。FETCH用來讀取遊標中的某一行資料。FETCH語句的文法格式:
FETCH           [ [ NEXT | PRIOR | FIRST | LAST                     | ABSOLUTE { n | @nvar }                     | RELATIVE { n | @nvar }                ]                FROM           ] { { [ GLOBAL ] cursor_name } | @cursor_variable_name } [ INTO @variable_name [ ,...n ] ] 
2.4 關閉遊標
  在不使用遊標的時候,可以將其關閉,以釋放遊標所佔用的伺服器資源。關閉遊標CLOSE文法格式:
CLOSE { { [ GLOBAL ] cursor_name } | cursor_variable_name }
2.5 釋放遊標
  遊標操作的結果集空間雖然被釋放了,但是遊標結構本身也會佔用一定的資源,所以在使用完遊標之後,為了收回被遊標佔用的資源,應該講遊標釋放。釋放遊標DEALLOCATE文法格式:
DEALLOCATE { { [ GLOBAL ] cursor_name } | @cursor_variable_name }
 
Sql Server系列:遊標