作者:手机用户2602897571 | 来源:互联网 | 2014-07-13 17:52
PL/SQL中可以使用%ROWTYPE作为一张表的行作为数就类型,%TYPE可以作为某字段作为数据类型,但需要指定的若干个字段作为一个数据类型,就可以使用PL/SQL记录实现。PL/SQL记录的定义语法:Sql代码...SyntaxHighlighter.all();
PL/SQL 中可以使用 %ROWTYPE 作为一张表的行作为数就类型,%TYPE 可以作为某字段作为数据类型,但需要指定的若干个字段作为一个数据类型,就可以使用 PL/SQL 记录实现。
PL/SQL 记录的定义语法:
Sql代码
TYPE type_name is RECORD(
filed_declaration[,
filed_declaration,
... www.2cto.com
filed_declaration]
);
identifier type_name
使用 PL/SQL 记录:
Sql代码
declare
--定义
TYPE nemp_record_type IS RECORD(
nno scott.emp.empno%TYPE,
nname scott.emp.ename%TYPE,
ndept scott.dept%ROWTYPE
);
nemp_record nemp_record_type;
eno number:=7788;
begin www.2cto.com
--将查询的结果赋给定义的 nemp_record,若 dept.* 一起赋值,则列数过多,无法赋值
SELECT e.empno,e.ename into nemp_record.nno,nemp_record.nname
from scott.emp e, scott.dept d WHERE e.deptno=d.deptno AND e.empno=eno;
SELECT * into nemp_record.ndept from scott.dept where deptno = (
select deptno from scott.emp where empno = eno
);
dbms_output.put_line(nemp_record.ndept.dname); --输出:RESEARCH
end;
摘自 Ear's blog