版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、SQL游標(biāo)原理和使用方法.txt54就讓昨日成流水,就讓往事隨風(fēng)飛,今日的杯中別再盛著昨日的殘痕;唯有珍惜現(xiàn)在,才能收獲明天。數(shù)據(jù)庫開發(fā)過程中,當(dāng)你檢索的數(shù)據(jù)只是一條記錄時(shí),你所編寫的事務(wù)語句代碼往往使用語句。但是我們常常會(huì)遇到這樣情況,即從某一結(jié)果集中逐一地讀取一條記錄。那么如何解決這種問題呢?游標(biāo)為我們提供了一種極為優(yōu)秀的解決方案。1.1游標(biāo)和游標(biāo)的優(yōu)點(diǎn)在數(shù)據(jù)庫中,游標(biāo)是一個(gè)十分重要的概念。游標(biāo)提供了一種對從表中檢索出的數(shù)據(jù)進(jìn)行操作
2、的靈活手段,就本質(zhì)而言,游標(biāo)實(shí)際上是一種能從包括多條數(shù)據(jù)記錄的結(jié)果集中每次提取一條記錄的機(jī)制。游標(biāo)總是與一條T_SQL選擇語句相關(guān)聯(lián)因?yàn)橛螛?biāo)由結(jié)果集(可以是零條、一條或由相關(guān)的選擇語句檢索出的多條記錄)和結(jié)果集中指向特定記錄的游標(biāo)位置組成。當(dāng)決定對結(jié)果集進(jìn)行處理時(shí),必須聲明一個(gè)指向該結(jié)果集的游標(biāo)。如果曾經(jīng)用C語言寫過對文件進(jìn)行處理的程序,那么游標(biāo)就像您打開文件所得到的文件句柄一樣,只要文件打開成功,該文件句柄就可代表該文件。對于游標(biāo)而言
3、,其道理是相同的??梢娪螛?biāo)能夠?qū)崿F(xiàn)按與傳統(tǒng)程序讀取平面文件類似的方式處理來自基礎(chǔ)表的結(jié)果集,從而把表中數(shù)據(jù)以平面文件的形式呈現(xiàn)給程序。我們知道關(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)行相同或不同的操作,而不是一次對整個(gè)結(jié)
4、果集進(jìn)行同一種操作;它還提供對基于游標(biāo)位置而對表中數(shù)據(jù)進(jìn)行刪除或更新的能力;而且,正是游標(biāo)把作為面向集合的數(shù)據(jù)庫管理系統(tǒng)和面向行的程序設(shè)計(jì)兩者聯(lián)系起來,使兩個(gè)數(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腳本、存儲(chǔ)過
5、程和觸發(fā)器中。Transact_SQL游標(biāo)主要用在服務(wù)器上,由從客戶端發(fā)送給服務(wù)器的Transact_SQL語句或是批處理、存儲(chǔ)過程、觸發(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ū)動(dòng)器或
6、DB_library的動(dòng)態(tài)鏈接庫(DLL)都會(huì)將這些客戶請求傳送給服務(wù)器以對API游標(biāo)進(jìn)行處理。(3)客戶游標(biāo)客戶游標(biāo)主要是當(dāng)在客戶機(jī)上緩存結(jié)果集時(shí)才使用。在客戶游標(biāo)中,有一個(gè)缺省的結(jié)果集被用來在客戶機(jī)上緩存整個(gè)結(jié)果集??蛻粲螛?biāo)僅支持靜態(tài)游標(biāo)而非動(dòng)態(tài)游標(biāo)。由于服務(wù)器游標(biāo)并不支持所有的TransactSQL語句或批處理,所以客戶游標(biāo)常常僅被用作服務(wù)器游標(biāo)的輔助。因?yàn)樵谝话闱闆r下,服務(wù)器游標(biāo)能支持絕大多數(shù)的游標(biāo)操作。由于API游標(biāo)和Tran
7、sactSQL游標(biāo)使用在服務(wù)器端,所以被稱為服務(wù)器游標(biāo),也被稱為后臺(tái)游標(biāo),而客戶端游標(biāo)被稱為前臺(tái)游標(biāo)。在本章中我們主要講述服務(wù)器(后臺(tái))游標(biāo)。用的系統(tǒng)性能和這條語句的復(fù)雜程度。如果執(zhí)行的時(shí)間較長可以考慮將屏幕上顯示的鼠標(biāo)改為hourglass。提取數(shù)據(jù)當(dāng)用OPEN語句打開了游標(biāo)并在數(shù)據(jù)庫中執(zhí)行了查詢后您不能立即利用在查詢結(jié)果集中的數(shù)據(jù)。您必須用FETCH語句來取得數(shù)據(jù)。一條FETCH語句一次可以將一條記錄放入程序員指定的變量中。事實(shí)上F
8、ETCH語句是游標(biāo)使用的核心。在DataWindow和DataSte中執(zhí)行了Retrieve()函數(shù)以后查詢的所有結(jié)果全部可以得到而使用游標(biāo)我們只能逐條記錄地得到查詢結(jié)果。已經(jīng)聲明并打開一個(gè)游標(biāo)后我們就可以將數(shù)據(jù)放入任意的變量中。在FETCH語句中您可以指定游標(biāo)的名稱和目標(biāo)變量的名稱。如下例:FETCHCustmerCursINTO:ls_acct_no:ls_name:ll_balance從語法上講上面所述的就是一條合法的取數(shù)據(jù)的語句
9、但是一般我們使用游標(biāo)卻還應(yīng)當(dāng)包括其它的部分。正如我們前面所談到的游標(biāo)只能一次從后臺(tái)數(shù)據(jù)庫中取一條記錄而在多數(shù)情況下我們所想要作的是在數(shù)據(jù)庫中從第一條記錄開始提取一直到結(jié)束。所以我們一般要將游標(biāo)提取數(shù)據(jù)的語句放在一個(gè)循環(huán)體內(nèi)直至將結(jié)果集中的全部數(shù)據(jù)提取后跳出循環(huán)圈。通過檢測SQLCA.SQLCODE的值可以得知最后一條FETCH語句是否成功。一般當(dāng)SQLCODE值為0時(shí)表明一切正常100表示已經(jīng)取到了結(jié)果集的末尾而其它值均表明操作出了問題
10、這樣我們可以編寫以下的代碼:lb_continue=Truell_total=0DOWHILElb_continueFETCHCustomerCursINTO:ls_acct_no:ls_name:ll_balanceIfsqlca.sqlcode=0Thenll_total=ll_balanceElselb_continue=FalseEndIfLOOP循環(huán)體的結(jié)構(gòu)有多種這里提到的是最常見的一種。也有的程序員喜愛將一條FETCH語句放
11、在循環(huán)體的前面循環(huán)體內(nèi)再放置另外一條FETCH語句并檢測SQLCA.SQLCODE是否為100。但是這樣做維護(hù)時(shí)需同時(shí)修改兩條FETCH語句稍麻煩了些。關(guān)閉游標(biāo)在游標(biāo)操作的最后請不要忘記關(guān)閉游標(biāo)這是一個(gè)好的編程習(xí)慣以使系統(tǒng)釋放游標(biāo)占用的資源。關(guān)閉游標(biāo)的語句很簡單:CLOSECustomerCurs使用Where子句子我們可以動(dòng)態(tài)地定義游標(biāo)中的Where子句的參數(shù)例如在本例中我們是直接定義了查詢省份是北京的記錄但也許在應(yīng)用中我們要使用一個(gè)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- sql游標(biāo)原理和使用方法
- 游標(biāo)卡尺的構(gòu)造、原理及使用方法和讀數(shù)
- 游標(biāo)卡尺使用方法
- sql 游標(biāo)使用
- 游標(biāo)卡尺使用方法33900
- 游標(biāo)卡尺的使用方法
- 游標(biāo)卡尺使用方法43630
- 常見游標(biāo)卡尺的使用方法
- oracle游標(biāo)使用方法及語法大全
- 游標(biāo)卡尺 的正確 使用方法
- 游標(biāo)卡尺的正確使用方法
- sql server游標(biāo)的使用
- 機(jī)械式游標(biāo)卡尺的使用方法
- 虛擬內(nèi)存技術(shù)原理和使用方法
- sql 游標(biāo)
- bet的原理及使用方法
- sql游標(biāo)
- 酶標(biāo)儀工作原理及使用方法
- 眼科b超原理及使用方法
- 認(rèn)識(shí)鍵盤和使用方法
評(píng)論
0/150
提交評(píng)論