游标的类型有两种:隐式游标和显式游标
说明:当进行表的数据查询操作, 一般用游标实现,
查询结果为单行的可以用隐式游标select … into …,
查询结果为多行的可以用显式游标cursor …;
1.隐式游标
(单行值写入变量可以用select … into …)
对变量赋值还可以使用SELECT…INTO 语句从数据库中查询数据对变量进行赋值。
**查询的结果只能是一行记录,不能是零行或者多行记录。**
打印出emp中员工编号为7369的姓名和工资。
DECLARE
V_ENAME VARCHAR2(10);
V_SAL NUMBER(7,2);
BEGIN
SELECT ENAME,SAL
INTO V_ENAME,V_SAL -- 隐士游标赋值(来源于表的查询结果,查询结果只能是单行)
FROM EMP WHERE EMPNO=7369;
DBMS_OUTPUT.PUT_LINE('员工名称:'||V_ENAME||' 员工工资:'||V_SAL); -- 不能直接打印表,只能是单行字段拼接后的字符串形式打印
END;
2.引用数据类型
%TYPE: 引用表中的某列的数据类型或某个变量的数据类型(单值变量,只能存储单值)。
%ROWTYPE:引用表中的一行(所有字段)作为数据类型(表变量,也只能一行一行的存储)。
打印出emp中员工编号为7369的姓名和工资。
--%TYPE 引用表单个字段类型
DECLARE
v_name emp.ename%TYPE; -- 引用表的单个字段类型(单值变量)
v_sal emp.sal%TYPE;
BEGIN
SELECT ename, sal
INTO v_name, v_sal
FROM emp
WHERE empno=7369;
dbms_output.put_line('姓名:' || v_name ||' 工资: ' ||v_sal);
END;
-- %ROWTYPE 引用表的所有字段类型
DECLARE
v_emp emp%ROWTYPE; -- 引用整个表的字段类型(表变量)
BEGIN
SELECT *
INTO v_emp -- 插入整行数据(所有字段数据)
FROM emp
WHERE empno=7369;
dbms_output.put_line('姓名:' || v_emp.ename ||' 工资: ' ||v_emp.sal); -- 不能直接打印整个表,只能是单个值的拼接
END;
3.显式游标
(多行值写入变量用显式游标)
游标的类型有两种:隐式游标和显式游标。
PL/SQL会为所有的SQL数据操作声明一个隐式的游标,包括只返回一条记录的查询操作。
显式游标四个步骤:
1.声明
2.打开游标
3.逐行获取数据
4.关闭游标
语法结构:声明游标
CURSOR 游标名[(参数1 数据类型[,参数2 数据类型...])]
IS SELECT 语句; --游标的声明
语法结构:执行游标
OPEN 游标名[(实际参数1[,实际参数2...])]; --打开游标
FETCH 游标名 INTO 变量名1[,变量名2...];
或
FETCH 游标名 INTO 记录变量; --提取数据
CLOSE 游标名; --关闭游标
FOR循环(比较方便)
DECLARE
CURSOR C_EMP IS
SELECT ENAME,SAL FROM EMP
WHERE DEPTNO=10;
BEGIN
FOR V_EMP IN C_EMP LOOP
DBMS_OUTPUT.PUT_LINE('姓名: ' || V_EMP.ENAME || '工资: ' || V_EMP.SAL);
END LOOP;
END;
需要游标参数
DECLARE
CURSOR C_EMP(P_DEPTNO EMP.DEPTNO%TYPE) IS -- 游标参数
SELECT ENAME,SAL
FROM EMP
WHERE DEPTNO=P_DEPTNO;
BEGIN
FOR V_EMP IN C_EMP(&部门号) LOOP -- 键盘输入变量值(键盘输入值时,字符型要加单引号)/打开游标的时候传入
DBMS_OUTPUT.PUT_LINE('姓名: ' || V_EMP.ENAME || '工资: ' || V_EMP.SAL);
END LOOP;
END;