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

下載本文檔

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

文檔簡介

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

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

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

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

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

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

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

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

9、取數(shù)據(jù)的語句放在一個循環(huán)體內(nèi)直至將結(jié)果集中的全部數(shù)據(jù)提取后跳出循環(huán)圈。通過檢測SQLCA.SQLCODE的值可以得知最后一條FETCH語句是否成功。一般當(dāng)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。但是這樣做維護(hù)時需同時修改兩條FETCH語句稍麻煩了些。關(guān)閉游標(biāo)在游標(biāo)操作的最后請不要忘記關(guān)閉游標(biāo)

溫馨提示

  • 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)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論