• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >oracle > 全面解析Oracle Procedure 基本语法

全面解析Oracle Procedure 基本语法

作者:无痕客 字体:[增加 减小] 来源:互联网 时间:2017-05-11

无痕客通过本文主要向大家介绍了oracle procedure语法,oracle procedure,oracle procedure out,oracle procedure if,oracle中procedure等相关知识,希望本文的分享对您有所帮助

关键字: oracle 存储过程

1.基本结构

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

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; 
 ... 
</div>

3.IF 判断

 IF V_TEST=1 THEN 
 BEGIN 
 do something 
 END; 
 END IF;
</div>

4.while 循环

WHILE V_TEST=1 LOOP 
 BEGIN 
XXXX 
 END; 
 END LOOP;
</div>

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;
</div>

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;
</div>

8.用pl/sql developer debug

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

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

转载:

oracle 存储过程

关键字: oracle 存储过程

存储过程创建语法:   

create or replace procedure 存储过程名(param1 in type,param2 out type)
</div>

as

变量1 类型(值范围);

变量2 类型(值范围);

Begin 
 Select count(*) into 变量1 from 表A where列名=param1; 
 If (判断条件) then 
 Select 列名 into 变量2 from 表A where列名=param1; 
 Dbms_output。Put_line(‘打印信息'); 
 Elsif (判断条件) then 
 Dbms_output。Put_line(‘打印信息'); 
 Else 
 Raise 异常名(NO_DATA_FOUND); 
 End if; 
Exception 
 When others then 
 Rollback; 
End;
</div>

注意事项:

1,  存储过程参数不带取值范围,in表示传入,out表示输出

2,  变量带取值范围,后面接分号

3,  在判断语句前最好先用count(*)函数判断是否存在该条操作记录

4,  用select 。。。into。。。给变量赋值

5,  在代码中抛异常用 raise+异常名

以命名的异常

命名的系统异常                          产生原因

ACCESS_INTO_NULL   未定义对象 
CASE_NOT_FOUND   CASE 中若未包含相应的 WHEN ,并且没有设置 
ELSE 时 
COLLECTION_IS_NULL  集合元素未初始化 
CURSER_ALREADY_OPEN  游标已经打开 
DUP_VAL_ON_INDEX   唯一索引对应的列上有重复的值 
INVALID_CURSOR   在不合法的游标上进行操作 
INVALID_NUMBER   内嵌的 SQL 语句不能将字符转换为数字 
NO_DATA_FOUND   使用 select into 未返回行,或应用索引表未初始化的 
TOO_MANY_ROWS   执行 select into 时,结果集超过一行 
ZERO_DIVIDE    除数为 0 
SUBSCRIPT_BEYOND_COUNT 元素下标超过嵌套表或 VARRAY 的最大值 
SUBSCRIPT_OUTSIDE_LIMIT 使用嵌套表或 VARRAY 时,将下标指定为负数 
VALUE_ERROR    赋值时,变量长度不足以容纳实际数据 
LOGIN_DENIED    PL/SQL 应用程序连接到 oracle 数据库时,提供了不 
正确的用户名或密码 
NOT_LOGGED_ON   PL/SQL 应用程序在没有连接 oralce 数据库的情况下 
访问数据 
PROGRAM_ERROR   PL/SQL 内部问题,可能需要重装数据字典& pl./SQL 
系统包 
ROWTYPE_MISMATCH  宿主游标变量与 PL/SQL 游标变量的返回类型不兼容 
SELF_IS_NULL    使用对象类型时,在 null 对象上调用对象方法 
STORAGE_ERROR   运行 PL/SQL 时,超出内存空间 
SYS_INVALID_ID    无效的 ROWID 字符串 
TIMEOUT_ON_RESOURCE  Oracle 在等待资源时超时
</div>

语法及示例:

1、存储过程创建存储过程的语法:

CREATE [OR REPLACE] PROCEDURE procedure_name[(parameter_list)]{IS|AS}[local_declarations]BEGINexecutable_statements[EXCEPTIONexception_handlers]END [procedure_name];
</div>

其中:procedure_name是过程的名称。

parameter_list是参数列表。

local_declarations是局部声明。

executable_statements是可执行语句。

exception_handlers是异常处理程序。

示例1:

演示创建过程(参数列表中为IN参数赋予一个默认值,不能为OUT、IN OUT参数赋予默认值)

create or replace procedure find_emp(emp_no in number:=7900)asempname varchar2(20);beginselect ename into empname from emp where empno=emp_no;dbms_output.put_line('雇员姓名是 '||empname);exceptionwhen no_data_found thendbms_output.put_line('雇员编号未找到');end find_emp;
</div>

调用过程:

EXECUTE procudure_name(parameters_list);
</div>

也可以在过程里面调用,直接写上procudure_name而不必写EXECUTE。

示例2:演示创建带OUT参数的过程

create or replace procedure test(value1 varchar2,value2 out number) is identity number; begin select sal into identity from emp where empno=value1; if identity<2000 then value2:=1000; else value2:=500; end if; end;
</div>

调用带OUT参数的过程:

declare value2 number; begin test('7900',value2); dbms_output.put_line(value2); end;
</div>

示例3:

演示创建带IN OUT参数的过程

create or replace procedure swap(p1 in out number,p2 in out number) is v_temp number; begin v_temp:=p1; p1:=p2; p2:=v_temp; end;
</div>

调用带IN OUT参数的过程:

declare num1 number:=100; num2 number:=200; begin swap(num1,num2); dbms_output.put_line('num1= '||num1); dbms_output.put_line('num2= '||num2); end;
</div>

示例4:将过程的执行权限授予其他用户

GRANT EXECUTE ON find_emp TO scott; GRANT EXECUTE ON swap TO PUBLIC; 
</div>

将find_emp过程的执行权限授予给用户scott,将执行swap过程的权限授予所有数据库用户。

删除过程语法:

DROP PROCEDURE procudure_name;
</div>

2、函数 定义函数的语法如下:

CREATE [OR REPLACE] FUNCTION function_name [(parameter_list)] RETURN datatype {IS|AS} [local_declarations] BEGIN executable_statements [EXCEPTION exception_handlers] END [function_name]; 
</div>

其中:function_name是函数的名称。

parameter_list是参数列表。

local_declarations是局部声明。

executable_statements是可执行语句。

exception_handlers是异常处理程序。

使用函数时注意:形式参数必须只使用数据库类型,不得使用PL/SQL类型。函数的返回类型也必须是数据库类型。

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • oracle中的procedure编写和使用详解
  • oracle中 procedure(存储过程)和function(函数)本质区别
  • 全面解析Oracle Procedure 基本语法

相关文章

  • 2017-05-11Oracle数据库设置任务计划备份一周的备份记录
  • 2017-05-11Oracle将字符编码从GBK转到UTF8,如何操作比较稳妥?
  • 2017-05-11解析Oracle中多表级联删除的方法
  • 2017-05-11ORACLE 正则解决初使化数据格式不一致
  • 2017-05-11Oracle截取字符串去掉字段末尾指定长度的字符
  • 2017-05-11Oracle 系统变量函数介绍
  • 2017-05-11oracle iSQL*PLUS配置设置图文说明
  • 2017-05-11Oracle生成单据编号存储过程的实例代码
  • 2017-05-11ORACLE时间函数(SYSDATE)深入理解
  • 2017-05-11探讨Oracle中的&号问题

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Oracle9i 动态SGA,PGA特性探索
    • Oracle SqlPlus设置Login.sql的技巧
    • Oracle 数据库中创建合理的数据库索引
    • 一些实用的sql语句
    • Oracle 数据库 练习题 T8
    • oracle适配器连接不上的解决办法
    • DB2和 Oracle的并发控制(锁)的比较
    • Oracle9i的全文检索技术开发者网络Oracle
    • oracle 11g的警告日志和监听日志的删除方法
    • oracle创建一个数据库三步走

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有