Oracle数据库创建存储过程的示例详解


当前第2页 返回上一页

2.0,游标的使用,看到的一段解释很好的概念,如下:

  •  游标是SQL的一个内存工作区,由系统或用户以变量的形式定义。游标的作用就是用于临时存储从数据库中提取的数据块。在某些情况下,需要把数据从存放
  •    在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。
  •    游标有两种类型:显式游标和隐式游标。在前述程序中用到的SELECT...INTO...查询语句,一次只能从数据库中提取一行数据,对于这种形式的查询和DML操作,
  •    系统都会使用一个隐式游标。但是如果要提取多行数据,就要由程序员定义一个显式游标,并通过与游标有关的语句进行处理。显式游标对应一个返回结果为多
  •    行多列的SELECT语句。
  •    游标一旦打开,数据就从数据库中传送到游标变量中,然后应用程序再从游标变量中分解出需要的数据,并进行处理。
  •    在我们进行insert、update、delete和select   value into  variable 的操作中,使用的是隐式游标
  •    隐式游标的属性 返回值类型意义            
  •    SQL%ROWCOUNT    整型  代表DML语句成功执行的数据行数  
  •    SQL%FOUND   布尔型 值为TRUE代表插入、删除、更新或单行查询操作成功  
  •    SQL%NOTFOUND    布尔型 与SQL%FOUND属性返回值相反  
  •    SQL%ISOPEN  布尔型 DML执行过程中为真,结束后为假 

 2.1,修改雇员薪资:

 CREATE OR REPLACE PROCEDURE job_day06(epo in number)
  AS
 BEGIN
  UPDATE EMPS SET SAL=(SAL+100) WHERE empno = epo;
  IF SQL%FOUND --SQL%FOUND是隐式游标 作用:判断SQL语句是否成功执行,当有作用行时则成功执行为true,否则为false。 6 THEN
  DBMS_OUTPUT.PUT_LINE('成功修改雇员工资!');
  commit;
  else
  DBMS_OUTPUT.PUT_LINE('修改雇员工资失败!');
  END IF;
 END;
 --调用存储过程
 declare
 e_number number;
 begin
 e_number:=1001;
 job_day06(e_number);
 end;

 2.2,查询编号为1001信息

CREATE OR REPLACE PROCEDURE job_day07
IS
BEGIN
DECLARE
 cursor emp_sor is select name,sal FROM EMPS WHERE EMPNO = '1001'; --声明游标
 cname EMPS.NAME%type; --%type 作用: 声明的变量ename与EMPS表的NAME列类型一样
 csal EMPS.SAL%type;
BEGIN
 open emp_sor; --打开游标
 loop
-- 取游标值给变量
 FETCH emp_sor into cname,csal;
 dbms_output.put_line('name:'||cname);
 exit when emp_sor%notfound;
 end loop;
 close emp_sor; --关闭游标
end;
end;
--调用存储过程
BEGIN
 job_day07();
END;

总结:

  存储过程通俗的理解就是就是一个执行过程,调用的时候给他所需要的需求就会对数据库进行操作,相当于我们自己手写Sql,只不过有了存储过程
  只要调用一下传给他参数他就会帮我们写,比较方便,灵活的运用存储过程会让我们开发很方便

到此这篇关于Oracle数据库创建存储过程的示例详解的文章就介绍到这了,更多相关Oracle数据库创建存储过程内容请搜索


打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...