2023年全國碩士研究生考試考研英語一試題真題(含答案詳解+作文范文)_第1頁
已閱讀1頁,還剩5頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、數(shù)據(jù)庫開發(fā)過程中,當你檢索的數(shù)據(jù)只是一條記錄時,你所編寫的事務(wù)語句代碼往往使用語句。但是我們常常會遇到這樣情況,即從某一結(jié)果集中逐一地讀取一條記錄。那么如何解決這種問題呢?游標為我們提供了一種極為優(yōu)秀的解決方案。1.1游標和游標的優(yōu)點在數(shù)據(jù)庫中,游標是一個十分重要的概念。游標提供了一種對從表中檢索出的數(shù)據(jù)進行操作的靈活手段,就本質(zhì)而言,游標實際上是一種能從包括多條數(shù)據(jù)記錄的結(jié)果集中每次提取一條記錄的機制。游標總是與一條T_SQL選擇語句

2、相關(guān)聯(lián)因為游標由結(jié)果集(可以是零條、一條或由相關(guān)的選擇語句檢索出的多條記錄)和結(jié)果集中指向特定記錄的游標位置組成。當決定對結(jié)果集進行處理時,必須聲明一個指向該結(jié)果集的游標。如果曾經(jīng)用C語言寫過對文件進行處理的程序,那么游標就像您打開文件所得到的文件句柄一樣,只要文件打開成功,該文件句柄就可代表該文件。對于游標而言,其道理是相同的??梢娪螛四軌?qū)崿F(xiàn)按與傳統(tǒng)程序讀取平面文件類似的方式處理來自基礎(chǔ)表的結(jié)果集,從而把表中數(shù)據(jù)以平面文件的形式呈現(xiàn)

3、給程序。我們知道關(guān)系數(shù)據(jù)庫管理系統(tǒng)實質(zhì)是面向集合的,在MSSQLSERVER中并沒有一種描述表中單一記錄的表達形式,除非使用where子句來限制只有一條記錄被選中。因此我們必須借助于游標來進行面向單條記錄的數(shù)據(jù)處理。由此可見,游標允許應(yīng)用程序?qū)Σ樵冋Z句返回的行結(jié)果集中每一行進行相同或不同的操作,而不是一次對整個結(jié)果集進行同一種操作;它還提供對基于游標位置而對表中數(shù)據(jù)進行刪除或更新的能力;而且,正是游標把作為面向集合的數(shù)據(jù)庫管理系統(tǒng)和面向

4、行的程序設(shè)計兩者聯(lián)系起來,使兩個數(shù)據(jù)處理方式能夠進行溝通。1.2游標種類MSSQLSERVER支持三種類型的游標:Transact_SQL游標,API服務(wù)器游標和客戶游標。(1)Transact_SQL游標Transact_SQL游標是由DECLARECURS語法定義、主要用在Transact_SQL腳本、存儲過程和觸發(fā)器中。Transact_SQL游標主要用在服務(wù)器上,由從客戶端發(fā)送給服務(wù)器的Transact_SQL語句或是批處理、存

5、儲過程、觸發(fā)器中的Transact_SQL進行管理。Transact_SQL游標不支持提取數(shù)據(jù)塊或多行數(shù)據(jù)。(2)API游標API游標支持在OLEDB,ODBC以及DB_library中使用游標函數(shù),主要用在服務(wù)器上。每一次客戶端應(yīng)用程序調(diào)用API游標函數(shù),MSSQLSEVER的OLEDB提供者、ODBC驅(qū)動器或DB_library的動態(tài)鏈接庫(DLL)都會將這些客戶請求傳送給服務(wù)器以對API游標進行處理。(3)客戶游標客戶游標主要是當

6、在客戶機上緩存結(jié)果集時才使用。在客戶游標中,有一個缺省的結(jié)果集被用來在客戶機上緩存整個結(jié)果集。客戶游標僅支持靜態(tài)游標而非動態(tài)游標。由于服務(wù)器游標并不支持所有的TransactSQL語句或批處理,所以客戶游標常常僅被用作服務(wù)器游標的輔助。因為在一般情況下,服務(wù)器游標能支持絕大多數(shù)的游標操作。由于API游標和TransactSQL游標使用在服務(wù)器端,所以被稱為服務(wù)器游標,也被稱為后臺游標,而客戶端游標被稱為前臺游標。在本章中我們主要講述服務(wù)

7、器(后臺)游標。count(id)frominfo提取數(shù)據(jù)當用OPEN語句打開了游標并在數(shù)據(jù)庫中執(zhí)行了查詢后您不能立即利用在查詢結(jié)果集中的數(shù)據(jù)。您必須用FETCH語句來取得數(shù)據(jù)。一條FETCH語句一次可以將一條記錄放入程序員指定的變量中。事實上FETCH語句是游標使用的核心。在DataWindow和DataSte中執(zhí)行了Retrieve()函數(shù)以后查詢的所有結(jié)果全部可以得到而使用游標我們只能逐條記錄地得到查詢結(jié)果。已經(jīng)聲明并打開一個游標

8、后我們就可以將數(shù)據(jù)放入任意的變量中。在FETCH語句中您可以指定游標的名稱和目標變量的名稱。如下例:FETCHCustmerCursINTO:ls_acct_no:ls_name:ll_balance從語法上講上面所述的就是一條合法的取數(shù)據(jù)的語句但是一般我們使用游標卻還應(yīng)當包括其它的部分。正如我們前面所談到的游標只能一次從后臺數(shù)據(jù)庫中取一條記錄而在多數(shù)情況下我們所想要作的是在數(shù)據(jù)庫中從第一條記錄開始提取一直到結(jié)束。所以我們一般要將游標提

9、取數(shù)據(jù)的語句放在一個循環(huán)體內(nèi)直至將結(jié)果集中的全部數(shù)據(jù)提取后跳出循環(huán)圈。通過檢測SQLCA.SQLCODE的值可以得知最后一條FETCH語句是否成功。一般當SQLCODE值為0時表明一切正常100表示已經(jīng)取到了結(jié)果集的末尾而其它值均表明操作出了問題這樣我們可以編寫以下的代碼:lb_continue=Truell_total=0DOWHILElb_continueFETCHCustomerCursINTO:ls_acct_no:ls_nam

10、e:ll_balanceIfsqlca.sqlcode=0Thenll_total=ll_balanceElselb_continue=FalseEndIfLOOP循環(huán)體的結(jié)構(gòu)有多種這里提到的是最常見的一種。也有的程序員喜愛將一條FETCH語句放在循環(huán)體的前面循環(huán)體內(nèi)再放置另外一條FETCH語句并檢測SQLCA.SQLCODE是否為100。但是這樣做維護時需同時修改兩條FETCH語句稍麻煩了些。關(guān)閉游標在游標操作的最后請不要忘記關(guān)閉游標

溫馨提示

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

評論

0/150

提交評論