图解Oracle存储过程教程

1 Oracle的工具有PLSQL和Oracle自带的SQL Developer,以下使用后者;

从开始菜单启动SQL Developer;

 

2 进入以前用scott账号建立的连接;

 

3 先输入下述语句统计下各个表的记录数;

看用哪个表做存储过程的示例;

 

4 后来想到不如用SCOTT账户下自带的表;Oracle自带的表EMP内容如下;

 

5 做第一个简单存储过程;输入下图语句,执行,出现下图错误;

 

6 再写一个如下图所示简单存储过程;执行;正确;结果如下图;

 

7 改正5的错误;因为网页拷过来的代码有时候会包含全角字符,全角空格不容易发现;故出现“无效的字符”;改正后执行,正确,代码和结果如下图;

 

8 存储过程返回结果集

Oracle不像SQLServer那样在存储过程中用Select就可以返回结果集,而是通过Out型的参数进行结果集返回的;

下图代码中,

cursor cursor_emp is select * from emp;    -- 定义游标

row_emp cursor_emp%rowtype;               -- 定义row_emp是游标中的行类型;

返回游标后循环输出获取的行集;

 

9 返回记录数和使用select into 语句,代码和结果如下图;

 

10 存储过程中的if语句;

输入型参数不能作为赋值目标;出现下图错误;

 

11 把参数类型改为 in out 类型,再编译;正确;然后执行,输入参数和执行结果如下图;

 

 

12 再做一个返回结果集,返回EMP表的SAL,代码和结果如下图;

 

13 存储过程中的while语句,代码和结果如下图;

以上代码经调试无误;下载:

http://pan.baidu.com/s/1eQ4FTAy

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值