真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

oracle如何聲明游標(biāo) oracle游標(biāo)的用法

如何使用Oracle的游標(biāo)?

Oracle中的游標(biāo)分為顯示游標(biāo)和隱式游標(biāo)。

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比秦皇島網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式秦皇島網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋秦皇島地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴。

顯示游標(biāo):

顯示游標(biāo)是用cursor...is命令定義的游標(biāo),它可以對(duì)查詢語句(select)返回的多條記錄進(jìn)行處理;顯示游標(biāo)的操作:打開游標(biāo)、操作游標(biāo)、關(guān)閉游標(biāo);

隱式游標(biāo):

隱式游標(biāo)是在執(zhí)行插入(insert)、刪除(delete)、修改(update)和返回單條記錄的查詢(select)語句時(shí)由PL/SQL自動(dòng)定義的。PL/SQL隱式地打開SQL游標(biāo),并在它內(nèi)部處理SQL語句,然后關(guān)閉它。

oracle中如何定義一個(gè)游標(biāo)?

1.游標(biāo)定義:

cursor XXXA is

SELECT 語句;

XXXB cursorName%rowtype;

XXXA: 游標(biāo)名

XXXB: 游標(biāo)行數(shù)據(jù)定義

2. 打開游標(biāo):

-- 打開之前最好先關(guān)一下,防止上次發(fā)生異常沒有關(guān)掉而引發(fā)不必要的異常

IF XXXA%ISOPEN THEN

CLOSE XXXA;

END IF;

Open XXXA ;

Loop

Fetch XXXA into XXXB;

exit when XXXA%NOTFOUND;

... ... 處理邏輯

end loop;

close XXXA;

游標(biāo)是什么?ORACLE是怎樣使用游標(biāo)的?舉例說明!

一 游標(biāo)是什么

游標(biāo)字面理解就是游動(dòng)的光標(biāo)。

用數(shù)據(jù)庫(kù)語言來描述:游標(biāo)是映射在結(jié)果集中一行數(shù)據(jù)上的位置實(shí)體,有了游標(biāo),用戶就可以訪問結(jié)果集中的任意一行數(shù)據(jù)了,將游標(biāo)放置到某行后,即可對(duì)該行數(shù)據(jù)進(jìn)行操作,例如提取當(dāng)前行的數(shù)據(jù)等。

二 游標(biāo)的分類

顯式游標(biāo)和隱式游標(biāo)

顯式游標(biāo)的使用需要4步:

1. 聲明游標(biāo)

CURSOR mycur(vartype number) is

select emp_no,emp_zc from cus_emp_basic

where com_no = vartype;

2. 打開游標(biāo)

open mycur(000627)

注:000627是參數(shù)

3. 讀取數(shù)據(jù)

fetch mycur into varno, varprice;

4. 關(guān)閉游標(biāo)

close mycur;

三 游標(biāo)的屬性

oracle 游標(biāo)有4個(gè)屬性:%ISOPEN,%FOUND,%NOTFOUND,%ROWCOUNT。

%ISOPEN判斷游標(biāo)是否被打開,如果打開%ISOPEN等于true,否則等于false;

%FOUND %NOTFOUND判斷游標(biāo)所在的行是否有效,如果有效,則%FOUNDD等于true,否則等于false;

%ROWCOUNT返回當(dāng)前位置為止游標(biāo)讀取的記錄行數(shù)。

四 示例

set serveroutput on;

declare

varno varchar2(20);

varprice varchar2(20);

CURSOR mycur(vartype number) is

select emp_no,emp_zc from cus_emp_basic

where com_no = vartype;

begin

if mycur%isopen = false then

open mycur(000627);

end if;

fetch mycur into varno,varprice;

while mycur%found

loop

dbms_output.put_line(varno||','||varprice);

if mycur%rowcount=2 then

exit;

end if;

fetch mycur into varno,varprice;

end loop;

close mycur;

end;

PL/SQL記錄的結(jié)構(gòu)和C語言中的結(jié)構(gòu)體類似,是由一組數(shù)據(jù)項(xiàng)構(gòu)成的邏輯單元。

PL/SQL記錄并不保存在數(shù)據(jù)庫(kù)中,它與變量一樣,保存在內(nèi)存空間中,在使用記錄時(shí)候,要首先定義記錄結(jié)構(gòu),然后聲明記錄變量。可以把PL/SQL記錄看作是一個(gè)用戶自定義的數(shù)據(jù)類型。

set serveroutput on;

declare

type person is record

(

empno cus_emp_basic.emp_no%type,

empzc cus_emp_basic.emp_zc%type);

person1 person;

cursor mycur(vartype number)is

select emp_no,emp_zc from cus_emp_basic

where com_no=vartype;

begin

if mycur%isopen = false then

open mycur(000627);

end if;

loop

fetch mycur into person1;

exit when mycur%notfound;

dbms_output.put_line('雇員編號(hào):'||person1.empno||',地址:'||person1.empzc);

end loop;

close mycur;

end;

典型游標(biāo)for 循環(huán)

游標(biāo)for循環(huán)示顯示游標(biāo)的一種快捷使用方式,它使用for循環(huán)依次讀取結(jié)果集中的行數(shù)據(jù),當(dāng)form循環(huán)開始時(shí),游標(biāo)自動(dòng)打開(不需要open),每循環(huán)一次系統(tǒng)自動(dòng)讀取游標(biāo)當(dāng)前行的數(shù)據(jù)(不需要fetch),當(dāng)退出for循環(huán)時(shí),游標(biāo)被自動(dòng)關(guān)閉(不需要使用close)。使用游標(biāo)for循環(huán)的時(shí)候不能使用open語句,fetch語句和close語句,否則會(huì)產(chǎn)生錯(cuò)誤。

set serveroutput on;

declare

cursor mycur(vartype number)is

select emp_no,emp_zc from cus_emp_basic

where com_no=vartype;

begin

for person in mycur(000627) loop

dbms_output.put_line('雇員編號(hào):'||person.emp_no||',地址:'||person.emp_zc);

end loop;

end;


本文題目:oracle如何聲明游標(biāo) oracle游標(biāo)的用法
分享URL:http://weahome.cn/article/hihchp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部