Sql Server系列:遊標

來源:互聯網
上載者:User

標籤: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系列:遊標

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.