亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

快速掌握Oracle數據庫游標的使用方法

2024-08-29 13:49:33
字體:
來源:轉載
供稿:網友
顯式游標 當查詢返回結果超過一行時,就需要一個顯式游標,此時用戶不能使用select into語句。PL/SQL治理隱式游標,當查詢開始時隱式游標打開,查詢結束時隱式游標自動關閉。顯式游標在PL/SQL塊的聲明部分聲明,在執行部分或異常處理部分打開,取出數據,關閉。 使用游標 這里要做一個聲明,我們所說的游標通常是指顯式游標,因此從現在起沒有非凡指明的情況,我們所說的游標都是指顯式游標。要在程序中使用游標,必須首先聲明游標。 聲明游標 語法:

CURSOR cursor_name IS select_statement;
在PL/SQL中游標名是一個未聲明變量,不能給游標名賦值或用于表達式中。 例:
DELCARE CURSOR C_EMP IS SELECT empno,ename,salary FROM emp WHERE salary>2000 ORDER BY ename; ........ BEGIN
在游標定義中SELECT語句中不一定非要表可以是視圖,也可以從多個表或視圖中選擇的列,甚至可以使用*來選擇所有的列 。打開游標 使用游標中的值之前應該首先打開游標,打開游標初始化查詢處理。打開游標的語法是:
OPEN cursor_name
cursor_name是在聲明部分定義的游標名。 例: OPEN C_EMP; 關閉游標。 語法: CLOSE cursor_name 例: CLOSE C_EMP; 從游標提取數據。從游標得到一行數據使用FETCH命令。每一次提取數據后,游標都指向結果集的下一行。語法如下: FETCH cursor_name INTO variable[,variable,...] 對于SELECT定義的游標的每一列,FETCH變量列表都應該有一個變量與之相對應,變量的類型也要相同。 例:
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
這段代碼無疑是非常麻煩的,假如有多行返回結果,可以使用循環并用游標屬性為結束循環的條件,以這種方式提取數據,程序的可讀性和簡潔性都大為提高,下面我們使用循環重新寫上面的程序:
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
  記錄變量 定義一個記錄變量使用TYPE命令和%ROWTYPE,關于%ROWsTYPE的更多信息請參閱相關資料。 記錄變量用于從游標中提取數據行,當游標選擇很多列的時候,那么使用記錄比為每列聲明一個變量要方便得多。 當在表上使用%ROWTYPE并將從游標中取出的值放入記錄中時,假如要選擇表中所有列,那么在SELECT子句中使用*比將所有列名列出來要得多。 例:
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也可以用游標名來定義,這樣的話就必須要首先聲明游標:
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;
帶參數的游標 與存儲過程和函數相似,可以將參數傳遞給游標并在查詢中使用。這對于處理在某種條件下打開游標的情況非常有用。它的語法如下:
CURSOR cursor_name[(parameter[,parameter],...)] IS select_statement;
定義參數的語法如下:
Parameter_name [IN] data_type[{:=DEFAULT} value]
與存儲過程不同的是,游標只能接受傳遞的值,而不能返回值。參數只定義數據類型,沒有大小。 另外可以給參數設定一個缺省值,當沒有參數值傳遞給游標時,就使用缺省值。游標中定義的參數只是一個占位符,在別處引用該參數不一定可靠。 在打開游標時給參數賦值,語法如下:
OPEN cursor_name[value[,value]....];
參數值可以是文字或變量。 例:
DECALRE CURSOR c_dept IS SELECT * FROM dept ORDER BY deptno; CURSOR c_emp (p_dept VARACHAR2) 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:=0; 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;
  游標FOR循環 在大多數時候我們在設計程序的時候都遵循下面的步驟: 1、打開游標。 2、開始循環。 3、從游標中取值。 4、那一行被返回。 5、處理。 6、關閉循環。 7、關閉游標。 可以簡單的把這一類代碼稱為游標用于循環。但還有一種循環與這種類型不相同,這就是FOR循環,用于FOR循環的游標按照正常的聲明方式聲明,它的優點在于不需要顯式的打開、關閉、取數據,測試數據的存在、定義存放數據的變量等等。游標FOR循環的語法如下:
FOR record_name IN (corsor_name[(parameter[,parameter]...)] (query_difinition) LOOP statements END LOOP;
下面我們用for循環重寫上面的例子:
DECALRE CURSOR c_dept IS SELECT deptno,dname FROM dept ORDER BY deptno; CURSOR c_emp (p_dept VARACHAR2) 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:=0; 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;
在游標FOR循環中使用查詢 在游標FOR循環中可以定義查詢,由于沒有顯式聲明所以游標沒有名字,記錄名通過游標查詢來定義。
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:=0; 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;
游標中的子查詢 語法如下:
CURSOR C1 IS SELECT * FROM emp WHERE deptno NOT IN (SELECT deptno FROM dept WHERE dname!='ACCOUNTING');
可以看出與SQL中的子查詢沒有什么區別。   游標中的更新和刪除 在PL/SQL中依然可以使用UPDATE和DELETE語句更新或刪除數據行。顯式游標只有在需要獲得多行數據的情況下使用。PL/SQL提供了僅僅使用游標就可以執行刪除或更新記錄的方法。 UPDATE或DELETE語句中的WHERE CURRENT OF子串專門處理要執行UPDATE或DELETE操作的表中取出的最近的數據。要使用這個方法,在聲明游標時必須使用FOR UPDATE子串,當對話使用FOR UPDATE子串打開一個游標時,所有返回集中的數據行都將處于行級(ROW-LEVEL)獨占式鎖定,其他對象只能查詢這些數據行,不能進行UPDATE、DELETE或SELECT...FOR UPDATE操作。 語法:
FOR UPDATE [OF [schema.]table.column[,[schema.]table.column].. [nowait]
在多表查詢中,使用OF子句來鎖定特定的表,假如忽略了OF子句,那么所有表中選擇的數據行都將被鎖定。假如這些數據行已經被其他會話鎖定,那么正常情況下Oracle將等待,直到數據行解鎖。 在UPDATE和DELETE中使用WHERE CURRENT OF子串的語法如下:
WHERE{CURRENT OF cursor_namesearch_condition}
例:
DELCARE CURSOR c1 IS SELECT empno,salary FROM emp WHERE comm IS NULL FOR UPDATE OF comm; v_comm NUMBER(10,2); BEGIN FOR r1 IN c1 LOOP IF r1.salary<500 THEN v_comm:=r1.salary*0.25; ELSEIF r1.salary<1000 THEN v_comm:=r1.salary*0.20; ELSEIF r1.salary<3000 THEN
v_comm:=r1.salary*0.15; ELSE v_comm:=r1.salary*0.12; END IF; UPDATE emp; SET comm=v_comm WHERE CURRENT OF c1l; END LOOP; END


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
懂色av中文一区二区三区天美| 成人免费福利视频| 久久影视电视剧免费网站清宫辞电视| 久久九九全国免费精品观看| 国产精品嫩草影院一区二区| 亚洲激情 国产| 高跟丝袜欧美一区| 亚洲色图av在线| 国产精品日韩专区| 亚洲美女精品久久| 国产精品久久久久久久久久东京| 久久久久亚洲精品成人网小说| 欧美激情精品久久久久久| 国产精国产精品| 国产一区私人高清影院| 2019中文字幕在线| 国产精品美女免费| 国产精品成av人在线视午夜片| 国产视频亚洲精品| 色婷婷**av毛片一区| 久久久久久久av| 在线观看国产欧美| 色悠悠久久88| 欧美裸体男粗大视频在线观看| 国产精品27p| 国产一区深夜福利| 国产精品久久久久久久久久99| 欧美视频免费在线| 久热国产精品视频| 亚洲第一精品夜夜躁人人爽| 精品久久久久久中文字幕| 超碰91人人草人人干| 久久精品成人欧美大片古装| 26uuu久久噜噜噜噜| 久久99视频免费| 色噜噜久久综合伊人一本| 久久天天躁狠狠躁夜夜爽蜜月| 91地址最新发布| 欧美人与性动交a欧美精品| 欧美在线播放视频| 亚洲人免费视频| 深夜成人在线观看| 亚洲欧美国产视频| 欧美亚洲激情视频| 一区二区三区天堂av| 日韩欧美在线中文字幕| xxx成人少妇69| 久久久久久亚洲精品| 精品日本美女福利在线观看| 美女福利视频一区| 国产精品视频一区二区三区四| 国产精品视频精品| 亚洲欧美日韩精品久久亚洲区| 欧美日韩视频在线| 国产福利视频一区二区| 69**夜色精品国产69乱| 国产精品三级美女白浆呻吟| 国产婷婷成人久久av免费高清| 亚洲欧美日韩精品久久奇米色影视| 亚洲精品一区av在线播放| 欧洲中文字幕国产精品| 奇米影视亚洲狠狠色| 久久亚洲精品中文字幕冲田杏梨| 亚洲免费人成在线视频观看| 欧美激情一区二区三区在线视频观看| 国产精品一区二区在线| 黑人巨大精品欧美一区免费视频| 91夜夜揉人人捏人人添红杏| 欧美日韩国产色| 久久久久久久爱| 亚洲在线www| 国产91精品在线播放| 国产69精品久久久久9999| 国产精品国产三级国产aⅴ浪潮| 国产精品亚洲аv天堂网| 正在播放欧美一区| 国内精品久久久久久影视8| 91免费视频网站| 成人激情视频在线播放| 亚洲a级在线播放观看| 中文字幕亚洲欧美日韩在线不卡| 精品偷拍各种wc美女嘘嘘| 国产精品成av人在线视午夜片| 国产精品一区二区久久国产| 欧美丰满少妇xxxx| 性欧美长视频免费观看不卡| 欧美高清视频在线| 热99精品只有里视频精品| 欧美黑人性视频| 日本三级韩国三级久久| 亚洲精品99久久久久中文字幕| 欧美综合激情网| 欧美成人合集magnet| 国产成人一区二区在线| 日韩欧美成人区| 国产成人黄色av| 精品日韩中文字幕| 91精品国产精品| 日韩中文字幕国产精品| 欧美激情亚洲自拍| 日韩电影免费在线观看中文字幕| 欧美性极品少妇精品网站| 色先锋久久影院av| 国产精品一区二区三区久久| 亚洲美腿欧美激情另类| 中文字幕一区二区三区电影| 8050国产精品久久久久久| 日韩精品电影网| 91在线中文字幕| 欧美精品在线看| 欧美精品一区二区三区国产精品| 日韩成人av一区| 欧美成人午夜激情在线| 欧美日韩美女在线观看| 欧美大片免费观看在线观看网站推荐| 青青草国产精品一区二区| 欧美不卡视频一区发布| 国产最新精品视频| 久久久久久国产精品三级玉女聊斋| 国产99久久精品一区二区| 隔壁老王国产在线精品| 欧美亚洲午夜视频在线观看| 久久久成人精品视频| 色哟哟入口国产精品| 97激碰免费视频| 国产精品视频自在线| 日韩精品免费视频| 日韩一二三在线视频播| 国产视频久久久久久久| 在线视频欧美日韩| 欧美大尺度激情区在线播放| 亚洲欧美一区二区激情| 精品久久久久久中文字幕| 在线看国产精品| 亚洲美女中文字幕| 亚洲福利视频二区| 国产精品天天狠天天看| 亚洲欧洲激情在线| 国产日韩换脸av一区在线观看| 国产精品久久久久久久一区探花| 精品久久久久久久久国产字幕| 亚洲人成在线一二| 国产一区二区三区三区在线观看| 一区二区欧美日韩视频| 疯狂蹂躏欧美一区二区精品| 日韩中文字幕亚洲| 欧美床上激情在线观看| 国产精品成人一区二区| 欧美日韩国产中文精品字幕自在自线| 亚洲无限乱码一二三四麻| 国产精品第一视频| 亚洲男人天堂2024| 亚洲91av视频| 九九精品视频在线| 久久精品久久久久久| 91av在线网站| 黑人巨大精品欧美一区二区一视频| 亚洲色图激情小说| 欧美日韩中文字幕综合视频| 国产亚洲美女精品久久久| 98午夜经典影视| 北条麻妃在线一区二区| 精品毛片网大全| 久久91亚洲人成电影网站|