游标的类型有两种:隐式游标和显式游标

说明:当进行表的数据查询操作, 一般用游标实现,
查询结果为单行的可以用隐式游标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;