sql游標原理和使用方法40175_第1頁
已閱讀1頁,還剩5頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、SQL游標原理和使用方法.txt54就讓昨日成流水,就讓往事隨風飛,今日的杯中別再盛著昨日的殘痕;唯有珍惜現在,才能收獲明天。數據庫開發(fā)過程中,當你檢索的數據只是一條記錄時,你所編寫的事務語句代碼往往使用語句。但是我們常常會遇到這樣情況,即從某一結果集中逐一地讀取一條記錄。那么如何解決這種問題呢?游標為我們提供了一種極為優(yōu)秀的解決方案。1.1游標和游標的優(yōu)點在數據庫中,游標是一個十分重要的概念。游標提供了一種對從表中檢索出的數據進行操作

2、的靈活手段,就本質而言,游標實際上是一種能從包括多條數據記錄的結果集中每次提取一條記錄的機制。游標總是與一條T_SQL選擇語句相關聯因為游標由結果集(可以是零條、一條或由相關的選擇語句檢索出的多條記錄)和結果集中指向特定記錄的游標位置組成。當決定對結果集進行處理時,必須聲明一個指向該結果集的游標。如果曾經用C語言寫過對文件進行處理的程序,那么游標就像您打開文件所得到的文件句柄一樣,只要文件打開成功,該文件句柄就可代表該文件。對于游標而言

3、,其道理是相同的??梢娪螛四軌驅崿F按與傳統(tǒng)程序讀取平面文件類似的方式處理來自基礎表的結果集,從而把表中數據以平面文件的形式呈現給程序。我們知道關系數據庫管理系統(tǒng)實質是面向集合的,在MSSQLSERVER中并沒有一種描述表中單一記錄的表達形式,除非使用where子句來限制只有一條記錄被選中。因此我們必須借助于游標來進行面向單條記錄的數據處理。由此可見,游標允許應用程序對查詢語句返回的行結果集中每一行進行相同或不同的操作,而不是一次對整個結

4、果集進行同一種操作;它還提供對基于游標位置而對表中數據進行刪除或更新的能力;而且,正是游標把作為面向集合的數據庫管理系統(tǒng)和面向行的程序設計兩者聯系起來,使兩個數據處理方式能夠進行溝通。1.2游標種類MSSQLSERVER支持三種類型的游標:Transact_SQL游標,API服務器游標和客戶游標。(1)Transact_SQL游標Transact_SQL游標是由DECLARECURS語法定義、主要用在Transact_SQL腳本、存儲過

5、程和觸發(fā)器中。Transact_SQL游標主要用在服務器上,由從客戶端發(fā)送給服務器的Transact_SQL語句或是批處理、存儲過程、觸發(fā)器中的Transact_SQL進行管理。Transact_SQL游標不支持提取數據塊或多行數據。(2)API游標API游標支持在OLEDB,ODBC以及DB_library中使用游標函數,主要用在服務器上。每一次客戶端應用程序調用API游標函數,MSSQLSEVER的OLEDB提供者、ODBC驅動器或

6、DB_library的動態(tài)鏈接庫(DLL)都會將這些客戶請求傳送給服務器以對API游標進行處理。(3)客戶游標客戶游標主要是當在客戶機上緩存結果集時才使用。在客戶游標中,有一個缺省的結果集被用來在客戶機上緩存整個結果集??蛻粲螛藘H支持靜態(tài)游標而非動態(tài)游標。由于服務器游標并不支持所有的TransactSQL語句或批處理,所以客戶游標常常僅被用作服務器游標的輔助。因為在一般情況下,服務器游標能支持絕大多數的游標操作。由于API游標和Tran

7、sactSQL游標使用在服務器端,所以被稱為服務器游標,也被稱為后臺游標,而客戶端游標被稱為前臺游標。在本章中我們主要講述服務器(后臺)游標。用的系統(tǒng)性能和這條語句的復雜程度。如果執(zhí)行的時間較長可以考慮將屏幕上顯示的鼠標改為hourglass。提取數據當用OPEN語句打開了游標并在數據庫中執(zhí)行了查詢后您不能立即利用在查詢結果集中的數據。您必須用FETCH語句來取得數據。一條FETCH語句一次可以將一條記錄放入程序員指定的變量中。事實上F

8、ETCH語句是游標使用的核心。在DataWindow和DataSte中執(zhí)行了Retrieve()函數以后查詢的所有結果全部可以得到而使用游標我們只能逐條記錄地得到查詢結果。已經聲明并打開一個游標后我們就可以將數據放入任意的變量中。在FETCH語句中您可以指定游標的名稱和目標變量的名稱。如下例:FETCHCustmerCursINTO:ls_acct_no:ls_name:ll_balance從語法上講上面所述的就是一條合法的取數據的語句

9、但是一般我們使用游標卻還應當包括其它的部分。正如我們前面所談到的游標只能一次從后臺數據庫中取一條記錄而在多數情況下我們所想要作的是在數據庫中從第一條記錄開始提取一直到結束。所以我們一般要將游標提取數據的語句放在一個循環(huán)體內直至將結果集中的全部數據提取后跳出循環(huán)圈。通過檢測SQLCA.SQLCODE的值可以得知最后一條FETCH語句是否成功。一般當SQLCODE值為0時表明一切正常100表示已經取到了結果集的末尾而其它值均表明操作出了問題

10、這樣我們可以編寫以下的代碼:lb_continue=Truell_total=0DOWHILElb_continueFETCHCustomerCursINTO:ls_acct_no:ls_name:ll_balanceIfsqlca.sqlcode=0Thenll_total=ll_balanceElselb_continue=FalseEndIfLOOP循環(huán)體的結構有多種這里提到的是最常見的一種。也有的程序員喜愛將一條FETCH語句放

11、在循環(huán)體的前面循環(huán)體內再放置另外一條FETCH語句并檢測SQLCA.SQLCODE是否為100。但是這樣做維護時需同時修改兩條FETCH語句稍麻煩了些。關閉游標在游標操作的最后請不要忘記關閉游標這是一個好的編程習慣以使系統(tǒng)釋放游標占用的資源。關閉游標的語句很簡單:CLOSECustomerCurs使用Where子句子我們可以動態(tài)地定義游標中的Where子句的參數例如在本例中我們是直接定義了查詢省份是北京的記錄但也許在應用中我們要使用一個

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論