![](https://static.zsdocx.com/FlexPaper/FileRoot/2019-8/27/15/b6f45f62-4659-49ce-8f43-6b80da1ac572/b6f45f62-4659-49ce-8f43-6b80da1ac572pic.jpg)
![oracle 游標(biāo)簡(jiǎn)明教程_第1頁(yè)](https://static.zsdocx.com/FlexPaper/FileRoot/2019-8/27/15/b6f45f62-4659-49ce-8f43-6b80da1ac572/b6f45f62-4659-49ce-8f43-6b80da1ac5721.gif)
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、acleacle游標(biāo)教程游標(biāo)教程SQL是用于訪問(wèn)ACLE數(shù)據(jù)庫(kù)的語(yǔ)言,PLSQL擴(kuò)展和加強(qiáng)了SQL的功能,它同時(shí)引入了更強(qiáng)的程序邏輯。PLSQL支持DML命令和SQL的事務(wù)控制語(yǔ)句。DDL在PLSQL中不被支持,這就意味作在PLSQL程序塊中不能創(chuàng)建表或其他任何對(duì)象。較好的PLSQL程序設(shè)計(jì)是在PLSQL塊中使用象DBMS_SQL這樣的內(nèi)建包或執(zhí)行EXECUTEIMMEDIATE命令建立動(dòng)態(tài)SQL來(lái)執(zhí)行DDL命令,PLSQL編譯器保證對(duì)
2、象引用以及用戶的權(quán)限。下面我們將討論各種用于訪問(wèn)ACLE數(shù)據(jù)庫(kù)的DDL和TCL語(yǔ)句。查詢查詢語(yǔ)句用于從數(shù)據(jù)庫(kù)中查詢數(shù)據(jù),當(dāng)在PLSQL中使用語(yǔ)句時(shí),要與INTO子句一起使用,查詢的返回值被賦予INTO子句中的變量,變量的聲明是在DELCARE中。INTO語(yǔ)法如下:[DISTICT|ALL]|column[column...]INTO(variable[variable...]|recd)FROMtable|(subquery)[alia
3、s]WHERE............PLSQL中語(yǔ)句只返回一行數(shù)據(jù)。如果超過(guò)一行數(shù)據(jù),那么就要使用顯式游標(biāo)(對(duì)游標(biāo)的討論我們將在后面進(jìn)行),INTO子句中要有與子句中相同列數(shù)量的變量。INTO子句中也可以是記錄變量。%TYPE%TYPE屬性屬性在PLSQL中可以將變量和常量聲明為內(nèi)建或用戶定義的數(shù)據(jù)類(lèi)型,以引用一個(gè)列名,同時(shí)繼承他的數(shù)據(jù)類(lèi)型和大小。這種動(dòng)態(tài)賦值方法是非常有用的,比如變量引用的列的數(shù)據(jù)類(lèi)型和大小改變了,如果使用了%TYP
4、E那么用戶就不必修改代碼,否則就必須修改代碼。例:v_empnoSCOTT.EMP.EMPNO%TYPEv_salaryEMP.SALARY%TYPE不但列名可以使用%TYPE而且變量、游標(biāo)、記錄,或聲明的常量都可以使用%TYPE。這對(duì)于定義相同數(shù)據(jù)類(lèi)型的變量非常有用。DELCAREENDDMLDML語(yǔ)句的結(jié)果語(yǔ)句的結(jié)果當(dāng)執(zhí)行一條DML語(yǔ)句后,DML語(yǔ)句的結(jié)果保存在四個(gè)游標(biāo)屬性中,這些屬性用于控制程序流程或者了解程序的狀態(tài)。當(dāng)運(yùn)行DML
5、語(yǔ)句時(shí),PLSQL打開(kāi)一個(gè)內(nèi)建游標(biāo)并處理結(jié)果,游標(biāo)是維護(hù)查詢結(jié)果的內(nèi)存中的一個(gè)區(qū)域,游標(biāo)在運(yùn)行DML語(yǔ)句時(shí)打開(kāi),完成后關(guān)閉。隱式游標(biāo)只使用SQL%FOUNDSQL%NOTFOUNDSQL%ROWCOUNT三個(gè)屬性.SQL%FOUNDSQL%NOTFOUND是布爾值,SQL%ROWCOUNT是整數(shù)值。SQL%FOUND和SQL%NOTFOUND在執(zhí)行任何DML語(yǔ)句前SQL%FOUND和SQL%NOTFOUND的值都是NULL在執(zhí)行DML語(yǔ)
6、句后,SQL%FOUND的屬性值將是:.TRUE:.TRUE:和UPDATE,至少有一行被或UPDATE..TRUE:INTO至少返回一行當(dāng)SQL%FOUND為T(mén)RUE時(shí)SQL%NOTFOUND為FALSE。SQL%ROWCOUNT在執(zhí)行任何DML語(yǔ)句之前,SQL%ROWCOUNT的值都是NULL對(duì)于INTO語(yǔ)句,如果執(zhí)行成功,SQL%ROWCOUNT的值為1如果沒(méi)有成功,SQL%ROWCOUNT的值為0,同時(shí)產(chǎn)生一個(gè)異常NO_DATA
7、_FOUND.SQL%ISOPENSQL%ISOPEN是一個(gè)布爾值,如果游標(biāo)打開(kāi),則為T(mén)RUE如果游標(biāo)關(guān)閉,則為FALSE.對(duì)于隱式游標(biāo)而言SQL%ISOPEN總是FALSE,這是因?yàn)殡[式游標(biāo)在DML語(yǔ)句執(zhí)行時(shí)打開(kāi),結(jié)束時(shí)就立即關(guān)閉。事務(wù)控制語(yǔ)句事務(wù)控制語(yǔ)句事務(wù)是一個(gè)工作的邏輯單元可以包括一個(gè)或多個(gè)DML語(yǔ)句,事物控制幫助用戶保證數(shù)據(jù)的一致性。如果事務(wù)控制邏輯單元中的任何一個(gè)DML語(yǔ)句失敗,那么整個(gè)事務(wù)都將回滾,在PLSQL中用戶可以明
溫馨提示
- 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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- spss簡(jiǎn)明教程
- trados簡(jiǎn)明教程
- 《98王碼簡(jiǎn)明教程》
- visualc++mfc簡(jiǎn)明教程
- 散熱風(fēng)扇簡(jiǎn)明教程
- vbs腳本編程簡(jiǎn)明教程
- 聯(lián)共布黨史簡(jiǎn)明教程
- 無(wú)紙化在線學(xué)習(xí)簡(jiǎn)明教程學(xué)員
- eviews軟件實(shí)證操作簡(jiǎn)明教程
- 數(shù)字電路簡(jiǎn)明教程習(xí)題
- 概率統(tǒng)計(jì)簡(jiǎn)明教程課件講義
- 電工學(xué)簡(jiǎn)明教程答案
- 電子白板使用簡(jiǎn)明教程
- 編碼器 sdk 簡(jiǎn)明教程
- 霉菌試驗(yàn)簡(jiǎn)明教程-實(shí)驗(yàn)部分
- python學(xué)習(xí)筆記與簡(jiǎn)明教程
- hspice簡(jiǎn)明教程(復(fù)旦大學(xué))
- 教材《電工學(xué)簡(jiǎn)明教程》
- visual c++ mfc 簡(jiǎn)明教程
- 電工學(xué)簡(jiǎn)明教程答案
評(píng)論
0/150
提交評(píng)論