oracle游标

aphrodite 2012-08-16

1,游标分为显示的游标和隐示的游标

隐式游标和显式游标

隐式游标显式游标PL/SQL维护,当执行查询时自动打开和关闭在程序中显式定义、打开、关闭,游标有一个名字。游标属性前缀是SQL游标属性的前缀是游标名属性%ISOPEN总是为FALSE%ISOPEN根据游标的状态确定值SELECT语句带有INTO子串,只有一行数据被处理可以处理多行数据,在程序中设置循环,取出每一行数据。

2.游标的使用

a.使用游标中的值之前应该首先打开游标

OPENcursor_name

b.游标提取数据

从游标得到一行数据使用FETCH命令。每一次提取数据后,游标都指向结果集的下一行。语法如下:

FETCH cursor_name INTO variable[,variable,...]

c.SELECT语句只返回一行数据。如果超过一行数据,使用游标

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

d.记录变量用于从游标中提取数据行,当游标选择很多列的时候,那么使用记录比为每列声明一个变量要方便得多。

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;

e.带参数的游标

与存储过程不同的是,游标只能接受传递的值,而不能返回值。参数只定义数据类型,没有大小。

另外可以给参数设定一个缺省值,当没有参数值传递给游标时,就使用缺省值。游标中定义的参数只是一个占位符,在别处引用该参数不一定可靠。

f.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;

3.cursor,refcursor,sys_refcursor的区别

refcursor属于动态cursor,可以动态打开。

与普通游标的区别是它可以返回到客户端,一般存储过程返回结果集就用这类型的游标。

sys_refcursor是oracle9i以后系统定义的一个refcursor。

相关推荐

李高峰 / 0评论 2020-05-25