版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、游標(biāo)和異常處理游標(biāo)和異常處理游標(biāo)的概念游標(biāo)的概念游標(biāo)是SQL的一個內(nèi)存工作區(qū),由系統(tǒng)或用戶以變量的形式定義。游標(biāo)的作用就是用于臨時存儲從數(shù)據(jù)庫中提取的數(shù)據(jù)塊。在某些情況下,需要把數(shù)據(jù)從存放在磁盤的表中調(diào)到計算機(jī)內(nèi)存中進(jìn)行處理,最后將處理結(jié)果顯示出來或最終寫回數(shù)據(jù)庫。這樣數(shù)據(jù)處理的速度才會提高,否則頻繁的磁盤數(shù)據(jù)交換會降低效率。游標(biāo)有兩種類型:顯式游標(biāo)和隱式游標(biāo)。在前述程序中用到的...INTO...查詢語句,一次只能從數(shù)據(jù)庫中提取一行數(shù)
2、據(jù),對于這種形式的查詢和DML操作,系統(tǒng)都會使用一個隱式游標(biāo)。但是如果要提取多行數(shù)據(jù),就要由程序員定義一個顯式游標(biāo),并通過與游標(biāo)有關(guān)的語句進(jìn)行處理。顯式游標(biāo)對應(yīng)一個返回結(jié)果為多行多列的語句。游標(biāo)一旦打開,數(shù)據(jù)就從數(shù)據(jù)庫中傳送到游標(biāo)變量中,然后應(yīng)用程序再從游標(biāo)變量中分解出需要的數(shù)據(jù),并進(jìn)行處理。隱式游標(biāo)隱式游標(biāo)如前所述,DML操作和單行語句會使用隱式游標(biāo),它們是:插入操作:。更新操作:UPDATE。刪除操作:。單行查詢操作:...INTO
3、...。當(dāng)系統(tǒng)使用一個隱式游標(biāo)時,可以通過隱式游標(biāo)的屬性來了解操作的狀態(tài)和結(jié)果,進(jìn)而控制程序的流程。隱式游標(biāo)可以使用名字SQL來訪問,但要注意,通過SQL游標(biāo)名總是只能訪問前一個DML操作或單行操作的游標(biāo)屬性。所以通常在剛剛執(zhí)行完操作之后,立即使用SQL游標(biāo)名來訪問屬性。游標(biāo)的屬性有四種,如下表所示。隱式游標(biāo)的屬性返回值類型意義SQL%ROWCOUNT整型代表DML語句成功執(zhí)行的數(shù)據(jù)行數(shù)SQL%FOUND布爾型值為TRUE代表插入、刪除
4、、更新或單行查詢操作成功SQL%NOTFOUND布爾型與SQL%FOUND屬性返回值相反SQL%ISOPEN布爾型DML執(zhí)行過程中為真,結(jié)束后為假范例:使用隱式游標(biāo)的屬性,判斷對雇員工資的修改是否成功。范例:使用隱式游標(biāo)的屬性,判斷對雇員工資的修改是否成功。SETSERVEROUTPUTONBEGINUPDATEempSETsal=sal100WHEREempno=1234定義記錄變量的方法如下:變量名表名|游標(biāo)名%ROWTYPE;其中
5、的表必須存在,游標(biāo)名也必須先定義。4關(guān)閉游標(biāo)CLOSE游標(biāo)名顯式游標(biāo)打開后,必須顯式地關(guān)閉。游標(biāo)一旦關(guān)閉,游標(biāo)占用的資源就被釋放,游標(biāo)變成無效,必須重新打開才能使用。范例:以下是使用顯式游標(biāo)的一個簡單練習(xí)。用游標(biāo)提取emp表中7788雇員的名稱和職務(wù)。(yb1.sql)SETSERVEROUTPUTONDECLAREv_enameVAR2(10)v_jobVAR2(10)CURSemp_cursISenamejobFROMempWHER
6、Eempno=7788BEGINOPENemp_cursFETCHemp_cursINTOv_enamev_jobDBMS_OUTPUT.PUT_LINE(v_ename||||v_job)CLOSEemp_cursEND說明:該程序通過定義游標(biāo)emp_curs,提取并顯示雇員7788的名稱和職務(wù)。作為對以上例子的改進(jìn),在以下訓(xùn)練中采用了記錄變量。范例:用游標(biāo)提取emp表中7788雇員的姓名、職務(wù)和工資。(yb2.sql)SETSERV
7、EROUTPUTONDECLARECURSemp_cursISenamejobsalFROMempWHEREempno=7788emp_recdemp_curs%ROWTYPEBEGINOPENemp_cursFETCHemp_cursINTOemp_recdDBMS_OUTPUT.PUT_LINE(emp_recd.ename||||emp_recd.job||||to_(emp_recd.sal))CLOSEemp_cursEND說
溫馨提示
- 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- oracle_7 異常 游標(biāo) 函數(shù)
- oracle游標(biāo)
- oracle游標(biāo)簡介
- oracle游標(biāo)錯誤
- oracle游標(biāo)介紹
- oracle游標(biāo)使用
- oracle游標(biāo)基礎(chǔ)
- oracle游標(biāo)32801
- oracle游標(biāo)32893
- oracle游標(biāo)32824
- oracle游標(biāo)實例
- oracle游標(biāo)管理
- oracle游標(biāo)使用大全
- oracle 游標(biāo)使用大全
- 實驗7 游標(biāo)和異常
- oracle 游標(biāo) 小例子
- oracle 游標(biāo)使用大全32940
- oracle 游標(biāo)使用大全33073
- oracle 游標(biāo)簡明教程
- oracle游標(biāo)使用大全32979
評論
0/150
提交評論