Oracle10g存储过程的创建与调用

1.基本结构
  CREATE OR REPLACE PROCEDURE 存储过程名字
  (
  参数1 IN 数据类型,
  参数2 IN 数据类型
  ) IS | AS
  变量1 数据类型; -- 定义变量,等于符号是 := 可给定默认值
  变量2 数据类型;
  BEGIN
--存储过程的业务(你想要做的事)
  END 存储过程名字

2.SELECT INTO STATEMENT
  将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND)
  例子:
  BEGIN
   select col1,col2 into 变量1,变量2 FROM 表名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
CREATE OR REPLACE PROCEDURE TEST(name in number)
  IS
  CURSOR cur IS select * FROM xxx; --这里是定义一个游标,把查询结果放入游标中,
--游标就象指针
  BEGIN
  FOR cur_result in cur LOOP
  BEGIN
   V_SUM :=cur_result.列名;
  END;
  END LOOP;
  END;
例:
CREATE OR REPLACE PROCEDURE TEST(name in number)
is
V_SUM varchar2(200);
cursor cur is select * from LAD_USER;
BEGIN
for V_RESULT in cur LOOP
BEGIN
V_SUM := V_RESULT.User_Name;
END;
end LOOP;
DBMS_OUTPUT.put_line(V_SUM); --输出命令
END TEST;

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单步调试

9调用存储过程 call 存储过程名(参数列表);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值