oracle存储过程

来源:百度知道 编辑:UC知道 时间:2024/05/13 07:20:03
create procedure dept_procedure (a in varchar2)
as v_a varchar2(20)
begin
set v_a := a;
select * from dept where dname = a;
end;
这里那有错!
小弟刚学存储过程。希望各位大哥多讲的关于过程的知识!
可以加分!

create table dept
(deptno number,
dname varchar2(20),
loc varchar2(20)
)
1.如果你是取出单个的,你可以定义一个或者多个变量,将取出的值赋给变量
例如:

create or replace procedure dept_procedure(a in varchar2)
is
v_no number;
v_a varchar2(20);
begin
select a.deptno,a.loc into v_no,v_a
from dept a
where a.dname=a;
dbms_output.put_line('学号为:'||v_no||);
end;
2.如果你取出的是一个结果集,你可以用游标(一个简单的例子)
create or replace procedure dept_procedure(a in varchar2,v_a out dept%rowtype)
is
--声明游标
cursor c_de(a in varchar2)
is select * from dept where dname=a;
begin
--打开游标,对其中找到的记录进行遍历
open c_de(a);
loop
fetch c_de into v_a;
exit when c_de%notfound;
end loop;
close c_de;
dbms_output.put_line('deptno:'||v_a.deptno);
dbms_output.put_line('dname:'||v_a.dname);
dbms_output.put_line('loc:'||v_a.loc);
end;

3.可注意:在创建存储过程的时候加上or replace,