Oracle procedure 存储过程

2024-02-18 09:58
文章标签 oracle 过程 存储 procedure

本文主要是介绍Oracle procedure 存储过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Oracle procedure 存储过程

Oracle procedure 基本语法:

CREATE [OR REPLACE] PROCEDURE 存储过程名[(参数 [IN|OUT|INOUT] 数据类型...)]
{IS|AS}
[说明部分,例如:变量声明]
BEGIN 
可执行部分
[EXCEPTION
错误处理部分]
END [存储过程名];
/


-- 创建存储过程
-- create procedure 'testproc'
create or replace procedure testproc
as
  cnt number(38);
begin
  select count(*) into cnt from dual;
  dbms_output.put_line('cnt: '||cnt);
end;
/


注意:
1.在 PROCEDURE 和 FUNCTION 中使用 IS/AS 并没有太大区别。但在 VIEW 中只能用 AS 而不能用 IS ,在 CURSOR 中只能用 IS 而不能用AS。IS/AS 后面一般跟变量声明。 


-- 查询创建的存储过程
col name for a30;
col type for a20;

-- show all
select * from user_source;

-- show some
select * from user_source where name like upper('%test%');

-- show one
select * from user_source where name = upper('testproc');


-- 查询存储过程状态(包括编译成功与否状态)
col object_name for a20;
col subobject_name for a20;
select object_name, status, last_ddl_time, created, timestamp from user_objects where object_name = upper('testproc');


-- 调用存储过程
-- call procedure 'testproc'
set serveroutput on;
begin
  testproc;
end;
/

直接在SQL命令行执行命令调用存储过程
set serveroutput on;
execute testproc;


-- 重新编译存储过程
alter procedure testproc compile;
select object_name, status, last_ddl_time, created, timestamp from user_objects where object_name = upper('testproc');


删除存储过程
drop procedure testpro;

 

使用游标查询多行结果集

SQL Server支持存储过程中使用 select * from  student 来查询结果集,但Oracle不支持,会报错Warning: Procedure  created  with  compilation  errors。
Oracle中可以使用游标来返回结果集合。

-- 查询结果为多行结果集。student表三个字段:id,name,age
create or replace procedure testproc2
is
  cursor cur_all is select id,name,age from student;  --定义游标 cur_all
  c_id student.id%type;     --声明变量分别用来保存查询表的各列
  c_name student.name%type;
  c_age student.age%type;
begin
open cur_all;        --打开游标
  loop                    --循环处理
    fetch cur_all into c_id,c_name,c_age;    --操作数据
    exit when cur_all%NOTFOUND;            --循环退出条件:最近的FETCH语句返回一行数据则为FALSE
    if cur_all%FOUND then                          --最近的FETCH语句返回一行数据则为TRUE
      dbms_output.put_line(c_id||' '||c_name||' '||c_age);
    end if;
  end loop;
close cur_all;     --关闭游标
end;
/

execute testproc2;
1 jack 20
2 lucy 21
3 happy 20
4 white 21
 

--带入参(IN)的存储过程,普通循环1
create or replace procedure testproc2(var1 in varchar2 default 'id name age')
is
  cursor cur_all is select id,name,age from student;  --定义游标 cur_all
  c_id student.id%type;                               --声明变量分别用来保存查询表的各列
  c_name student.name%type;
  c_age student.age%type;
begin
dbms_output.put_line(var1);
open cur_all;                                         --打开游标
  loop                                                --循环处理
    fetch cur_all into c_id,c_name,c_age;             --操作数据
    exit when cur_all%NOTFOUND;                       --循环退出条件:最近的FETCH语句返回一行数据则为FALSE
    if cur_all%FOUND then                             --最近的FETCH语句返回一行数据则为TRUE
      dbms_output.put_line(c_id||' '||c_name||' '||c_age);
    end if;
  end loop;
close cur_all;                                        --关闭游标
end;
/


--带入参(IN)的存储过程,普通循环2
create or replace procedure testproc2(var1 in varchar2 default 'id name age')
is
  cursor cur_all is select * from student;  --定义游标 cur_all
  cur_line student%rowtype;                 --定义rowtype
begin
dbms_output.put_line(var1);
open cur_all;                                         --打开游标
  loop                                                --循环处理
    fetch cur_all into cur_line;                      --操作数据
    exit when cur_all%NOTFOUND;                       --循环退出条件:最近的FETCH语句返回一行数据则为FALSE
    if cur_all%FOUND then                             --最近的FETCH语句返回一行数据则为TRUE
      dbms_output.put_line(cur_line.id||' '||cur_line.name||' '||cur_line.age);
    end if;
  end loop;
close cur_all;                                        --关闭游标
end;
/

 

execute testproc2
id name age
1 jack 20
2 lucy 21
3 happy 20
4 white 21

execute testproc2('id2, name2, age2')
id2, name2, age2
1 jack 20
2 lucy 21
3 happy 20
4 white 21

call testproc2();
id name age
1 jack 20
2 lucy 21
3 happy 20
4 white 21

call testproc2('id3 name3 age3');
id3 name3 age3
1 jack 20
2 lucy 21
3 happy 20
4 white 21
 

--带入参(IN)的存储过程,用"for in"使用cursor(游标)
create or replace procedure testproc2(var1 in varchar2 default 'id name age')
is
  cursor cur_all is select * from student;  --定义游标 cur_all
  cur_line student%rowtype;                 --定义rowtype
begin
dbms_output.put_line(var1);
  for cur_line in cur_all loop              --循环处理,隐式打开游标
    dbms_output.put_line(cur_line.id||' '||cur_line.name||' '||cur_line.age); --隐式执行一个fetch
  end loop;
--隐式关闭游标
end;
/
 

--带入参(IN)的存储过程,用 bulk collect 批量检索,效率更高
create or replace procedure testproc2(var1 in varchar2 default 'id name age')
is
  cursor cur_all is select * from student;      --定义游标 cur_all
  type student_tab is table of student%rowtype; --定义类型 student_tab
  student_rd student_tab;                       --定义变量 student_rd
begin
  dbms_output.put_line(var1);
  open cur_all;
  loop                   --循环处理,隐式打开游标
    fetch cur_all bulk collect into student_rd limit 500;
      for i in 1..student_rd.count loop             --循环处理
        dbms_output.put_line(student_rd(i).id||' '||student_rd(i).name||' '||student_rd(i).age);
      end loop;
    exit when cur_all%NOTFOUND;       --循环退出条件:最近的FETCH语句返回一行数据则为FALSE
  end loop;
  close cur_all;
end;
/
 


--带出参(OUT)的存储过程,简单样例
create or replace procedure testproc2(ret out varchar2)
is
begin
  ret := 'test002';
end;
/

declare
ret varchar2(255):='test001';
begin
  dbms_output.put_line(ret); --ret 原值
  testproc2(ret);
  dbms_output.put_line(ret); --ret 新值
end;
/

输出结果:
test001
test002


--带入参(IN)、出参(OUT)的存储过程,用"for in"使用cursor(游标)
create or replace procedure testproc2(var1 in varchar2 default 'id name age', var2 out varchar2)
is
  cursor cur_all is select * from student;  --定义游标 cur_all
  cur_line student%rowtype;                 --定义rowtype
begin
  dbms_output.put_line(var1);
  for cur_line in cur_all loop              --循环处理,隐式打开游标
    --dbms_output.put_line(cur_line.id||' '||cur_line.name||' '||cur_line.age); --隐式执行一个fetch
    var2 := var2||cur_line.id||' '||cur_line.name||' '||cur_line.age||chr(13)||chr(10);
  end loop;
--隐式关闭游标
end;
/

执行存储过程
declare
  ret varchar2(8000);
begin
  testproc2('id name age', ret);
  dbms_output.put_line(ret);
end;
/

结果如下:

id name age
1 jack 20
2 lucy 21
3 happy 20
4 white 21

 

这篇关于Oracle procedure 存储过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/720792

相关文章

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

MySQL中的InnoDB单表访问过程

《MySQL中的InnoDB单表访问过程》:本文主要介绍MySQL中的InnoDB单表访问过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、访问类型【1】const【2】ref【3】ref_or_null【4】range【5】index【6】

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

SQLite3 在嵌入式C环境中存储音频/视频文件的最优方案

《SQLite3在嵌入式C环境中存储音频/视频文件的最优方案》本文探讨了SQLite3在嵌入式C环境中存储音视频文件的优化方案,推荐采用文件路径存储结合元数据管理,兼顾效率与资源限制,小文件可使用B... 目录SQLite3 在嵌入式C环境中存储音频/视频文件的专业方案一、存储策略选择1. 直接存储 vs

浏览器插件cursor实现自动注册、续杯的详细过程

《浏览器插件cursor实现自动注册、续杯的详细过程》Cursor简易注册助手脚本通过自动化邮箱填写和验证码获取流程,大大简化了Cursor的注册过程,它不仅提高了注册效率,还通过友好的用户界面和详细... 目录前言功能概述使用方法安装脚本使用流程邮箱输入页面验证码页面实战演示技术实现核心功能实现1. 随机

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

CSS3打造的现代交互式登录界面详细实现过程

《CSS3打造的现代交互式登录界面详细实现过程》本文介绍CSS3和jQuery在登录界面设计中的应用,涵盖动画、选择器、自定义字体及盒模型技术,提升界面美观与交互性,同时优化性能和可访问性,感兴趣的朋... 目录1. css3用户登录界面设计概述1.1 用户界面设计的重要性1.2 CSS3的新特性与优势1.

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指