版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、游標(biāo)是SQL的一個(gè)內(nèi)存工作區(qū),由系統(tǒng)或用戶以變量的形式定義。游標(biāo)的作用就是用于臨時(shí)存儲(chǔ)從數(shù)據(jù)庫(kù)中提取的數(shù)據(jù)塊。在某些情況下,需要把數(shù)據(jù)從存放在磁盤的表中調(diào)到計(jì)算機(jī)內(nèi)存中進(jìn)行處理,最后將處理結(jié)果顯示出來(lái)或最終寫回?cái)?shù)據(jù)庫(kù)。這樣數(shù)據(jù)處理的速度才會(huì)提高,否則頻繁的磁盤數(shù)據(jù)交換會(huì)降低效率。游標(biāo)有兩種類型:顯式游標(biāo)和隱式游標(biāo)。在前述程序中用到的...INTO...查詢語(yǔ)句,一次只能從數(shù)據(jù)庫(kù)中提取一行數(shù)據(jù),對(duì)于這種形式的查詢和DML操作,系統(tǒng)都會(huì)使用
2、一個(gè)隱式游標(biāo)。但是如果要提取多行數(shù)據(jù),就要由程序員定義一個(gè)顯式游標(biāo),并通過(guò)與游標(biāo)有關(guān)的語(yǔ)句進(jìn)行處理。顯式游標(biāo)對(duì)應(yīng)一個(gè)返回結(jié)果為多行多列的語(yǔ)句。游標(biāo)一旦打開,數(shù)據(jù)就從數(shù)據(jù)庫(kù)中傳送到游標(biāo)變量中,然后應(yīng)用程序再?gòu)挠螛?biāo)變量中分解出需要的數(shù)據(jù),并進(jìn)行處理。隱式游標(biāo)如前所述,DML操作和單行語(yǔ)句會(huì)使用隱式游標(biāo),它們是:插入操作:。更新操作:UPDATE。刪除操作:。單行查詢操作:...INTO...。當(dāng)系統(tǒng)使用一個(gè)隱式游標(biāo)時(shí),可以通過(guò)隱式游標(biāo)的屬性
3、來(lái)了解操作的狀態(tài)和結(jié)果,進(jìn)而控制程序的流程。隱式游標(biāo)可以使用名字SQL來(lái)訪問(wèn),但要注意,通過(guò)SQL游標(biāo)名總是只能訪問(wèn)前一個(gè)DML操作或單行操作的游標(biāo)屬性。所以通常在剛剛執(zhí)行完操作之后,立即使用SQL游標(biāo)名來(lái)訪問(wèn)屬性。游標(biāo)的屬性有四種,如下所示。Sql代碼1.隱式游標(biāo)的屬性返回值類型意義2.SQL%ROWCOUNT整型代表DML語(yǔ)句成功執(zhí)行的數(shù)據(jù)行數(shù)3.SQL%FOUND布爾型值為TRUETRUE代表插入、刪除、更新或單行查詢操作成功4.
4、SQL%NOTFOUND布爾型與SQL%FOUND屬性返回值相反5.SQL%ISOPEN布爾型DML執(zhí)行過(guò)程中為真,結(jié)束后為假Sql代碼1.隱式游標(biāo)的屬性返回值類型意義2.SQL%ROWCOUNT整型代表DML語(yǔ)句成功執(zhí)行的數(shù)據(jù)行數(shù)3.SQL%FOUND布爾型值為TRUE代表插入、刪除、更新或單行查詢操作成功4.SQL%NOTFOUND布爾型與SQL%FOUND屬性返回值相反5.SQL%ISOPEN布爾型DML執(zhí)行過(guò)程中為真,結(jié)束后為假
5、【訓(xùn)練1】使用隱式游標(biāo)的屬性,判斷對(duì)雇員工資的修改是否成功。步驟1:輸入和運(yùn)行以下程序:1.成功修改雇員工資!2.PLSQL過(guò)程已成功完成。Sql代碼1.成功修改雇員工資!2.PLSQL過(guò)程已成功完成。說(shuō)明:本例中,通過(guò)SQL%FOUND屬性判斷修改是否成功,并給出相應(yīng)信息。顯式游標(biāo)游標(biāo)的定義和操作游標(biāo)的使用分成以下4個(gè)步驟。1聲明游標(biāo)在DECLEAR部分按以下格式聲明游標(biāo):CURS游標(biāo)名[(參數(shù)1數(shù)據(jù)類型[,參數(shù)2數(shù)據(jù)類型...])]
6、IS語(yǔ)句參數(shù)是可選部分,所定義的參數(shù)可以出現(xiàn)在語(yǔ)句的WHERE子句中。如果定義了參數(shù),則必須在打開游標(biāo)時(shí)傳遞相應(yīng)的實(shí)際參數(shù)。語(yǔ)句是對(duì)表或視圖的查詢語(yǔ)句,甚至也可以是聯(lián)合查詢??梢詭HERE條件、DERBY或GROUPBY等子句,但不能使用INTO子句。在語(yǔ)句中可以使用在定義游標(biāo)之前定義的變量。2打開游標(biāo)在可執(zhí)行部分,按以下格式打開游標(biāo):OPEN游標(biāo)名[(實(shí)際參數(shù)1[,實(shí)際參數(shù)2...])]打開游標(biāo)時(shí),語(yǔ)句的查詢結(jié)果就被傳送到了游標(biāo)工作
7、區(qū)。3提取數(shù)據(jù)在可執(zhí)行部分,按以下格式將游標(biāo)工作區(qū)中的數(shù)據(jù)取到變量中。提取操作必須在打開游標(biāo)之后進(jìn)行。FETCH游標(biāo)名INTO變量名1[,變量名2...]或FETCH游標(biāo)名INTO記錄變量游標(biāo)打開后有一個(gè)指針指向數(shù)據(jù)區(qū),F(xiàn)ETCH語(yǔ)句一次返回指針?biāo)傅囊恍袛?shù)據(jù),要返回多行需重復(fù)執(zhí)行,可以使用循環(huán)語(yǔ)句來(lái)實(shí)現(xiàn)??刂蒲h(huán)可以通過(guò)判斷游標(biāo)的屬性來(lái)進(jìn)行。下面對(duì)這兩種格式進(jìn)行說(shuō)明:第一種格式中的變量名是用來(lái)從游標(biāo)中接收數(shù)據(jù)的變量,需要事先定義。變量
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- oracle游標(biāo)使用大全
- oracle 游標(biāo)使用大全
- oracle 游標(biāo)使用大全32940
- oracle 游標(biāo)使用大全33073
- oracle游標(biāo)使用大全32979
- oracle 游標(biāo)使用大全33042
- oracle 游標(biāo)使用大全32990
- oracle游標(biāo)使用全解
- oracle游標(biāo)使用大全33021
- oracle游標(biāo)的使用及屬性
- oracle游標(biāo)的使用及屬性
- oracle數(shù)據(jù)庫(kù)游標(biāo)使用大全
- oracle 數(shù)據(jù)庫(kù)游標(biāo)使用大全
- oracle游標(biāo)
- oracle游標(biāo)使用方法及語(yǔ)法大全
- oracle游標(biāo)簡(jiǎn)介
- oracle游標(biāo)錯(cuò)誤
- oracle游標(biāo)介紹
- oracle游標(biāo)基礎(chǔ)
- oracle游標(biāo)32801
評(píng)論
0/150
提交評(píng)論