欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

oracle怎么更新游標(biāo) oracle游標(biāo)的使用

快速掌握Oracle數(shù)據(jù)庫(kù)游標(biāo)的使用方法

顯式游標(biāo)

創(chuàng)新互聯(lián)公司主要從事成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)贛州,10余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來(lái)電咨詢建站服務(wù):18980820575

當(dāng)查詢返回結(jié)果超過(guò)一行時(shí) 就需要一個(gè)顯式游標(biāo) 此時(shí)用戶不能使用select into語(yǔ)句 PL/SQL管理隱式游標(biāo) 當(dāng)查詢開(kāi)始時(shí)隱式游標(biāo)打開(kāi) 查詢結(jié)束時(shí)隱式游標(biāo)自動(dòng)關(guān)閉 顯式游標(biāo)在PL/SQL塊的聲明部分聲明 在執(zhí)行部分或異常處理部分打開(kāi) 取出數(shù)據(jù) 關(guān)閉

使用游標(biāo)

這里要做一個(gè)聲明 我們所說(shuō)的游標(biāo)通常是指顯式游標(biāo) 因此從現(xiàn)在起沒(méi)有特別指明的情況 我們所說(shuō)的游標(biāo)都是指顯式游標(biāo) 要在程序中使用游標(biāo) 必須首先聲明游標(biāo)

聲明游標(biāo)

語(yǔ)法

CURSOR cursor_name IS select_statement;

在PL/SQL中游標(biāo)名是一個(gè)未聲明變量 不能給游標(biāo)名賦值或用于表達(dá)式中

DELCARE CURSOR C_EMP IS SELECT empno ename salary FROM emp WHERE salary ORDER BY ename; BEGIN

在游標(biāo)定義中SELECT語(yǔ)句中不一定非要表可以是視圖 也可以從多個(gè)表或視圖中選擇的列 甚至可以使用*來(lái)選擇所有的列

打開(kāi)游標(biāo)

使用游標(biāo)中的值之前應(yīng)該首先打開(kāi)游標(biāo) 打開(kāi)游標(biāo)初始化查詢處理 打開(kāi)游標(biāo)的語(yǔ)法是

OPEN cursor_name

cursor_name是在聲明部分定義的游標(biāo)名

OPEN C_EMP; 關(guān)閉游標(biāo)

語(yǔ)法

CLOSE cursor_name

CLOSE C_EMP; 從游標(biāo)提取數(shù)據(jù) 從游標(biāo)得到一行數(shù)據(jù)使用FETCH命令 每一次提取數(shù)據(jù)后 游標(biāo)都指向結(jié)果集的下一行 語(yǔ)法如下

FETCH cursor_name INTO variable[ variable ]

對(duì)于SELECT定義的游標(biāo)的每一列 FETCH變量列表都應(yīng)該有一個(gè)變量與之相對(duì)應(yīng) 變量的類型也要相同

SET SERVERIUTPUT ON DECLARE v_ename EMP ENAME%TYPE; v_salary EMP SALARY%TYPE; CURSOR c_emp IS SELECT ename salary FROM emp; BEGIN OPEN c_emp; FETCH c_emp INTO v_ename v_salary; DBMS_OUTPUT PUT_LINE( Salary of Employee || v_ename || is || v_salary); FETCH c_emp INTO v_ename v_salary; DBMS_OUTPUT PUT_LINE( Salary of Employee || v_ename || is || v_salary); FETCH c_emp INTO v_ename v_salary; DBMS_OUTPUT PUT_LINE( Salary of Employee || v_ename || is || v_salary); CLOSE c_emp; END

這段代碼無(wú)疑是非常麻煩的 如果有多行返回結(jié)果 可以使用循環(huán)并用游標(biāo)屬性為結(jié)束循環(huán)的條件 以這種方式提取數(shù)據(jù) 程序的可讀性和簡(jiǎn)潔性都大為提高 下面我們使用循環(huán)重新寫(xiě)上面的程序

SET SERVERIUTPUT ON DECLARE v_ename EMP ENAME%TYPE; v_salary EMP SALARY%TYPE; CURSOR c_emp IS SELECT ename salary FROM emp; BEGIN OPEN c_emp; LOOP FETCH c_emp INTO v_ename v_salary; EXIT WHEN c_emp%NOTFOUND; DBMS_OUTPUT PUT_LINE( Salary of Employee || v_ename || is || v_salary); END

記錄變量

定義一個(gè)記錄變量使用TYPE命令和%ROWTYPE 關(guān)于%ROWsTYPE的更多信息請(qǐng)參閱相關(guān)資料

記錄變量用于從游標(biāo)中提取數(shù)據(jù)行 當(dāng)游標(biāo)選擇很多列的時(shí)候 那么使用記錄比為每列聲明一個(gè)變量要方便得多

當(dāng)在表上使用%ROWTYPE并將從游標(biāo)中取出的值放入記錄中時(shí) 如果要選擇表中所有列 那么在SELECT子句中使用*比將所有列名列出來(lái)要得多

SET SERVERIUTPUT ON DECLARE R_emp EMP%ROWTYPE; CURSOR c_emp IS SELECT * FROM emp; BEGIN OPEN c_emp; LOOP FETCH c_emp INTO r_emp; EXIT WHEN c_emp%NOTFOUND; DBMS_OUT PUT PUT_LINE( Salary of Employee ||r_emp ename|| is || r_emp salary); END LOOP; CLOSE c_emp; END;

%ROWTYPE也可以用游標(biāo)名來(lái)定義 這樣的話就必須要首先聲明游標(biāo)

SET SERVERIUTPUT ON DECLARE CURSOR c_emp IS SELECT ename salary FROM emp; R_emp c_emp%ROWTYPE; BEGIN OPEN c_emp; LOOP FETCH c_emp INTO r_emp; EXIT WHEN c_emp%NOTFOUND; DBMS_OUT PUT PUT_LINE( Salary of Employee ||r_emp ename|| is || r_emp salary); END LOOP; CLOSE c_emp; END;

帶參數(shù)的游標(biāo)

與存儲(chǔ)過(guò)程和函數(shù)相似 可以將參數(shù)傳遞給游標(biāo)并在查詢中使用 這對(duì)于處理在某種條件下打開(kāi)游標(biāo)的情況非常有用 它的語(yǔ)法如下

CURSOR cursor_name[(parameter[ parameter] )] IS select_statement;

定義參數(shù)的語(yǔ)法如下

Parameter_name [IN] data_type[{:=|DEFAULT} value]

與存儲(chǔ)過(guò)程不同的是 游標(biāo)只能接受傳遞的值 而不能返回值 參數(shù)只定義數(shù)據(jù)類型 沒(méi)有大小

另外可以給參數(shù)設(shè)定一個(gè)缺省值 當(dāng)沒(méi)有參數(shù)值傳遞給游標(biāo)時(shí) 就使用缺省值 游標(biāo)中定義的參數(shù)只是一個(gè)占位符 在別處引用該參數(shù)不一定可靠

在打開(kāi)游標(biāo)時(shí)給參數(shù)賦值 語(yǔ)法如下

OPEN cursor_name[value[ value] ];

參數(shù)值可以是文字或變量

DECALRE CURSOR c_dept IS SELECT * FROM dept ORDER BY deptno; CURSOR c_emp (p_dept VARACHAR ) IS SELECT ename salary FROM emp WHERE deptno=p_dept ORDER BY ename r_dept DEPT%ROWTYPE; v_ename EMP ENAME%TYPE; v_salary EMP SALARY%TYPE; v_tot_salary EMP SALARY%TYPE; BEGIN OPEN c_dept; LOOP FETCH c_dept INTO r_dept; EXIT WHEN c_dept%NOTFOUND; DBMS_OUTPUT PUT_LINE ( Department: || r_dept deptno|| ||r_dept dname); v_tot_salary:= ; OPEN c_emp(r_dept deptno); LOOP FETCH c_emp INTO v_ename v_salary; EXIT WHEN c_emp%NOTFOUND; DBMS_OUTPUT PUT_LINE ( Name: || v_ename|| salary: ||v_salary); v_tot_salary:=v_tot_salary+v_salary; END LOOP; CLOSE c_emp; DBMS_OUTPUT PUT_LINE ( Toltal Salary for dept: || v_tot_salary); END LOOP; CLOSE c_dept; END;

游標(biāo)FOR循環(huán)

在大多數(shù)時(shí)候我們?cè)谠O(shè)計(jì)程序的時(shí)候都遵循下面的步驟

打開(kāi)游標(biāo)

開(kāi)始循環(huán)

從游標(biāo)中取值

那一行被返回

處理

關(guān)閉循環(huán)

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

可以簡(jiǎn)單的把這一類代碼稱為游標(biāo)用于循環(huán) 但還有一種循環(huán)與這種類型不相同 這就是FOR循環(huán) 用于FOR循環(huán)的游標(biāo)按照正常的聲明方式聲明 它的優(yōu)點(diǎn)在于不需要顯式的打開(kāi) 關(guān)閉 取數(shù)據(jù) 測(cè)試數(shù)據(jù)的存在 定義存放數(shù)據(jù)的變量等等 游標(biāo)FOR循環(huán)的語(yǔ)法如下

FOR record_name IN (corsor_name[(parameter[ parameter] )] | (query_difinition) LOOP statements END LOOP;

下面我們用for循環(huán)重寫(xiě)上面的例子

DECALRE CURSOR c_dept IS SELECT deptno dname FROM dept ORDER BY deptno; CURSOR c_emp (p_dept VARACHAR ) IS SELECT ename salary FROM emp WHERE deptno=p_dept ORDER BY ename v_tot_salary EMP SALARY%TYPE; BEGIN FOR r_dept IN c_dept LOOP DBMS_OUTPUT PUT_LINE ( Department: || r_dept deptno|| ||r_dept dname); v_tot_salary:= ; FOR r_emp IN c_emp(r_dept deptno) LOOP DBMS_OUTPUT PUT_LINE ( Name: || v_ename || salary: || v_salary); v_tot_salary:=v_tot_salary+v_salary; END LOOP; DBMS_OUTPUT PUT_LINE ( Toltal Salary for dept: || v_tot_salary); END LOOP; END;

在游標(biāo)FOR循環(huán)中使用查詢

在游標(biāo)FOR循環(huán)中可以定義查詢 由于沒(méi)有顯式聲明所以游標(biāo)沒(méi)有名字 記錄名通過(guò)游標(biāo)查詢來(lái)定義

DECALRE v_tot_salary EMP SALARY%TYPE; BEGIN FOR r_dept IN (SELECT deptno dname FROM dept ORDER BY deptno) LOOP DBMS_OUTPUT PUT_LINE( Department: || r_dept deptno|| ||r_dept dname); v_tot_salary:= ; FOR r_emp IN (SELECT ename salary  FROM emp  WHERE deptno=p_dept  ORDER BY ename) LOOP DBMS_OUTPUT PUT_LINE( Name: || v_ename|| salary: ||v_salary); v_tot_salary:=v_tot_salary+v_salary; END LOOP; DBMS_OUTPUT PUT_LINE( Toltal Salary for dept: || v_tot_salary); END LOOP; END;

游標(biāo)中的子查詢

語(yǔ)法如下

CURSOR C IS SELECT * FROM emp WHERE deptno NOT IN (SELECT deptno FROM dept WHERE dname!= ACCOUNTING );

可以看出與SQL中的子查詢沒(méi)有什么區(qū)別

游標(biāo)中的更新和刪除

在PL/SQL中依然可以使用UPDATE和DELETE語(yǔ)句更新或刪除數(shù)據(jù)行 顯式游標(biāo)只有在需要獲得多行數(shù)據(jù)的情況下使用 PL/SQL提供了僅僅使用游標(biāo)就可以執(zhí)行刪除或更新記錄的方法

UPDATE或DELETE語(yǔ)句中的WHERE CURRENT OF子串專門處理要執(zhí)行UPDATE或DELETE操作的表中取出的最近的數(shù)據(jù) 要使用這個(gè)方法 在聲明游標(biāo)時(shí)必須使用FOR UPDATE子串 當(dāng)對(duì)話使用FOR UPDATE子串打開(kāi)一個(gè)游標(biāo)時(shí) 所有返回集中的數(shù)據(jù)行都將處于行級(jí)(ROW LEVEL)獨(dú)占式鎖定 其他對(duì)象只能查詢這些數(shù)據(jù)行 不能進(jìn)行UPDATE DELETE或SELECT FOR UPDATE操作

語(yǔ)法

FOR UPDATE [OF [schema ]lumn[ [schema ]lumn] [nowait]

在多表查詢中 使用OF子句來(lái)鎖定特定的表 如果忽略了OF子句 那么所有表中選擇的數(shù)據(jù)行都將被鎖定 如果這些數(shù)據(jù)行已經(jīng)被其他會(huì)話鎖定 那么正常情況下ORACLE將等待 直到數(shù)據(jù)行解鎖

在UPDATE和DELETE中使用WHERE CURRENT OF子串的語(yǔ)法如下

WHERE{CURRENT OF cursor_name|search_condition}

DELCARE CURSOR c IS SELECT empno salary FROM emp WHERE m IS NULL FOR UPDATE OF m; v_m NUMBER( ); BEGIN FOR r IN c LOOP IF r salary THEN v_m:=r salary* ; ELSEIF r salary THEN v_m:=r salary* ; ELSEIF r salary THEN v_m:=r salary* ; ELSE v_m:=r salary* ; END IF; UPDATE emp; SET m=v_m WHERE CURRENT OF c l; END LOOP; END

lishixinzhi/Article/program/Oracle/201311/16865

oracle 使用游標(biāo)更新數(shù)據(jù)問(wèn)題

先 set serveroutput on;

然后創(chuàng)建過(guò)程及調(diào)用。

如果不行,試試END LOOP前加COMMIT。

如果還是不行,先設(shè)置一個(gè)常量,測(cè)試下游標(biāo)是否正常運(yùn)行,然后再改。

把游標(biāo)定義更改為

cursor c_type is

select * from stu a where ......

本來(lái)是用手機(jī)看的、你本身的代碼定義的游標(biāo)是三表連接,你下面update的只是stu表的內(nèi)容、

為什么游標(biāo)類型定義三表聯(lián)合呢?

ORACLE PL/SQL游標(biāo)變量如何更新數(shù)據(jù)

ORACLE PL/SQL游標(biāo)變量如何更新數(shù)據(jù)

: for cursor select 字段 from; 然后 for loop update就行, 代碼很短,

分享文章:oracle怎么更新游標(biāo) oracle游標(biāo)的使用
標(biāo)題網(wǎng)址:http://chinadenli.net/article20/hhjgco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站小程序開(kāi)發(fā)自適應(yīng)網(wǎng)站域名注冊(cè)網(wǎng)站制作手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都app開(kāi)發(fā)公司