Oracle数据库学习笔记四——存储过程的值传递和引用传递

简介: Oracle数据库学习笔记四——存储过程的值传递和引用传递

编程语言中的4种子例程:

由两种行为定义,即形式值是否返回以及参数列表是值传递还是引用传递。

如果返回输出,子例程就是函数,如果不返回,就是过程。

所以4中子例程为:

1.值传递函数

2.引用传递函数

3.值传递过程

4.引用传递过程


pl/sql值传递过程由下列5条规则定义:


1.所有形参必须使用in模式定义为只写变量。(只能传入,不能传出)

2.所有形参必须是局部作用域的变量,不能再过程执行期间改变。(不能给in模式的参数赋值)

3.所有形参可使用任意有效的sql或pl/sql数据类型

4.所有形参可以有默认的初值

5.任何从sql查询到函数的系统引用游标类型的强制转换都是不可写的,因此必须通过in模式参数进行传递。

 这包括哪些作为显示游标变量传递的以及使用cursor函数的强制转换。


--值传递:调用时接受值的副本,不返回输出变量。 
 --使用值传递过程跨单个事务作用域管理多个DML语句。
 create or replace procedure add_user(
   username varchar2,
   age number,
   address varchar2,
   street_address varchar2
 )  is
 v_id number;
 --声明内部函数(内部pl/sql块) 从指定序列中获得下一个值,使用了本地动态sql
 function get_sequence_value(sequence_name varchar2) return number is
    pragma autonomous_transaction;
    id_value number;
    statement varchar2(2000);
 begin
    statement :='begin'                              ||chr(10)
              ||' select '||sequence_name||'.nextval'||chr(10)
              ||' into :id_value'                    ||chr(10)
              ||' from dual;'                        ||chr(10) 
              ||'end;';   
    execute immediate statement using out id_value;
    return id_value;
  end get_sequence_value;
begin
    savepoint add_user;       --设置保存点
    v_id :=get_sequence_value('SQ_USER');
    insert into tb_user(userid,name,age) values(v_id,username,age);
    if address is not null then
         --向地址表中插入值
         if street_address is not null then
            --向街道表中插入值
          end if;
    end if;
    exception
       when others then
          rollback to add_user;   --回滚到保存点
          raise_application_error(-20001,sqlerrm);  --抛出异常
end add_user;


--引用传递过程


--被调用时接受值的副本,不返回输出变量,可改变实参的值。返回实参引用给调用程序单元。

pl/sql引用传递过程由下列5条规则定义:

1.必须至少有一个形参通过使用out或in out模式定义。

2.所有形参在过程操作中可更改的局部作用域变量。

3.所有形参可使用任意有效的sql或pl/sql数据类型。

4.所有in模式形参可以有默认的初值。

5.任何从sql查询到过程的系统引用游标类型的强制转换都是不可写的,因此必须通过in模式参数进行传递。

 (即作为参数的系统引用游标不能再写入数据,只能是in模式的参数)


--例:引用传递过程
 function get_sequence_value(sequence_name varchar2) return number is
    pragma autonomous_transaction;
    id_value number;
    statement varchar2(2000);
 begin
    statement :='begin'                              ||chr(10)
              ||' select '||sequence_name||'.nextval'||chr(10)
              ||' into :id_value'                    ||chr(10)
              ||' from dual;'                        ||chr(10) 
              ||'end;';   
    execute immediate statement using out id_value;
    return id_value;
  end get_sequence_value;
 create or replace procedure add_user(
   username varchar2,
   age number,
   userid out number,   --输出参数(引用传递)
 )  is
 v_id number;
begin
    savepoint add_user;       --设置保存点
    userid :=get_sequence_value('SQ_USER');  --为输出参数赋值
    insert into tb_user(userid,name,age) values(userid,username,age);
    exception
       when others then
          rollback to add_user;   --回滚到保存点
          raise_application_error(-20001,sqlerrm);  --抛出异常
end add_user;


目录
相关文章
|
11天前
|
存储 Oracle 关系型数据库
数据库数据恢复—ORACLE常见故障的数据恢复方案
Oracle数据库常见故障表现: 1、ORACLE数据库无法启动或无法正常工作。 2、ORACLE ASM存储破坏。 3、ORACLE数据文件丢失。 4、ORACLE数据文件部分损坏。 5、ORACLE DUMP文件损坏。
47 11
|
24天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
1月前
|
存储 Oracle 关系型数据库
oracle数据恢复—Oracle数据库文件大小变为0kb的数据恢复案例
存储掉盘超过上限,lun无法识别。管理员重组存储的位图信息并导出lun,发现linux操作系统上部署的oracle数据库中有上百个数据文件的大小变为0kb。数据库的大小缩水了80%以上。 取出&并分析oracle数据库的控制文件。重组存储位图信息,重新导出控制文件中记录的数据文件,发现这些文件的大小依然为0kb。
|
17天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。
|
1月前
|
SQL Oracle 关系型数据库
Oracle数据库优化方法
【10月更文挑战第25天】Oracle数据库优化方法
49 7
|
1月前
|
存储 Oracle 关系型数据库
oracle服务器存储过程中调用http
通过配置权限、创建和调用存储过程,您可以在Oracle数据库中使用UTL_HTTP包发起HTTP请求。这使得Oracle存储过程可以与外部HTTP服务进行交互,从而实现更复杂的数据处理和集成。在实际应用中,根据具体需求调整请求类型和错误处理逻辑,以确保系统的稳定性和可靠性。
63 0
|
11天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
81 15
|
5天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
12天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
16天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。

推荐镜像

更多
下一篇
DataWorks