Oracle存储过程的基本语法

日期: 2008-06-17 来源:TechTarget中国

  1.基本结构


  create OR REPLACE PROCEDURE存储过程名字
  (
      参数1 IN NUMBER,
      参数2 IN NUMBER
  ) IS
  变量1 INTEGER :=0;
  变量2 DATE;
  BEGIN


  END 存储过程名字


  2.select INTO STATEMENT


  将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND)


   例子:
   BEGIN
   select col1,col2 into 变量1,变量2 FROM typestruct where xxx;
   EXCEPTION
   WHEN NO_DATA_FOUND THEN
       xxxx;
   END;
   …


  3.IF 判断


   IF V_TEST=1 THEN
     BEGIN
        do something
     END;
   END IF;


  4.while 循环


   WHILE V_TEST=1 LOOP
   BEGIN
  XXXX
   END;
   END LOOP;


  5.变量赋值


   V_TEST := 123;


  6.用for in 使用cursor


   …
   IS
   CURSOR cur IS select * FROM xxx;
   BEGIN
  FOR cur_result in cur LOOP
   BEGIN
    V_SUM :=cur_result.列名1+cur_result.列名2
   END;
  END LOOP;
   END;


  7.带参数的cursor


   CURSOR C_USER(C_ID NUMBER) IS select NAME FROM USER where TYPEID=C_ID;
   OPEN C_USER(变量值);
   LOOP
  FETCH C_USER INTO V_NAME;
  EXIT FETCH C_USER%NOTFOUND;
     do something
   END LOOP;
   CLOSE C_USER;


  8.用pl/sql developer debug


   连接数据库后建立一个Test WINDOW


   在窗口输入调用SP的代码,F9开始debug,CTRL+N单步调试

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

相关推荐