阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle-procedure/cursor解读

453次阅读
没有评论

共计 3621 个字符,预计需要花费 10 分钟才能阅读完成。

procedure 系列

Oracle-procedure 解读

Oracle 存储过程和自定义函数

procedure 概述

存储过程(Stored Procedure)是一组为了完成特定功能的 SQL 语句集,经编译后存储在数据库中。

用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。

存储过程是由流控制和 SQL 语句书写的过程,这个过程经编译和优化后存储在数据库服务器中,应用程序使用时只要调用即可。

在 Oracle 中,若干个有联系的过程可以组合在一起构成程序包。


procedure 优点

  • 存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般 SQL 语句每执行一次就编译一次, 所以使用存储过程可提高数据库执行速度。

  • 当对数据库进行复杂操作时 (如对多个表进行 Update、Insert、Query、Delete 时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。

  • 存储过程可以重复使用, 可减少数据库开发人员的工作量。

  • 安全性高, 可设定只有某用户才具有对指定存储过程的使用权。


和 function 的区别

Oracle-procedure/cursor 解读


procedure 例子

CREATE OR REPLACE procedure proc_trade(v_tradeid     in number, -- 交易 id
       v_third_ip    in varchar2, -- 第三方 ip
       v_third_time  in date, -- 第三方完成时间
       v_thire_state in number, -- 第三方状态
       o_result      out number, -- 返回值
       o_detail      out varchar2 -- 详细描述
      ) as
  -- 定义变量
  v_error varchar2(500);
begin
  -- 对变量赋值
  o_result := 0;
  o_detail := '验证失败';
  -- 业务逻辑处理
  if v_tradeid > 100 then
    insert into table_name (.. .) values (.. .);
    commit;
  elsif v_tradeid < 100 and v_tradeid > 50 then
    insert into table_name (.. .) values (.. .);
    commit;
  else
    goto log;
  end if;
  -- 跳转标志符,名称自己指定
  <<log>>
  o_result := 1;
  -- 捕获异常
exception
  when no_data_found then
    result := 2;
  when dup_val_on_index then
    result := 3;
  when others then
    result := -1;
end proc_trade;

参数类型可以自己指定,这种写法可行,但是最好使用 %type 来获取参数的类型 (table_name.column_name%TYPE)。这样就不会出现参数类型的错误。


存储过程中的循环

for … in … loop 循环

循环遍历游标

示例 1:

CREATE OR REPLACE PROCEDURE proc_test AS
  CURSOR c1 IS
    SELECT * FROM dat_trade;
BEGIN
  FOR x IN c1 LOOP
    DBMS_OUTPUT.put_line(x.id);
  END LOOP;
END proc_test;

示例 2:

CREATE OR REPLACE PROCEDURE proc_test AS
BEGIN
  FOR x IN (SELECT power_id FROM sys_power) LOOP
    DBMS_OUTPUT.put_line(x.power_id);
  END LOOP;
END proc_test;

根据数值进行循环

栗子一

CREATE OR REPLACE PROCEDURE proc_test() AS
BEGIN
  for x in 1 .. 100 loop
    dbms_output.put_line(x);
  end loop;
END proc_test;

栗子 2:在过程里指定输入参数 v_num. 在调用过程时指定循环次数。

CREATE OR REPLACE PROCEDURE proc_test(v_num IN NUMBER) AS
BEGIN
  FOR x IN 1 .. v_num LOOP
    DBMS_OUTPUT.put_line(x);
  END LOOP;
END proc_test;

loop 循环

LOOP
DELETE FROM orders
WHERE senddate < TO_CHAR (ADD_MONTHS (SYSDATE, -3),
'yyyy-mm-dd')
AND ROWNUM < 1000;
EXIT WHEN SQL%ROWCOUNT < 1;
COMMIT;
END LOOP;

这 里 的 SQL%ROWCOUNT 是 隐 士 游 标。除 了 这 个,还 有 其 他 几
个:%found,%notfound,%isopen。


while 循环

CREATE OR REPLACE PROCEDURE proc_test(v_num IN NUMBER) 
  AS
  i NUMBER := 1;
BEGIN
  WHILE i < v_num LOOP
    BEGIN
      i := i + 1;
      DBMS_OUTPUT.put_line(i);
    END;
  END LOOP;
END proc_test;

存储过程中的判断

if … elsif … else … 判断

CREATE OR REPLACE PROCEDURE proc_test(v_num IN NUMBER) AS
BEGIN
  IF v_num < 10 THEN
    DBMS_OUTPUT.put_line(v_num);
  ELSIF v_num > 10 AND v_num < 50 THEN
    DBMS_OUTPUT.put_line(v_num - 10);
  ELSE
    DBMS_OUTPUT.put_line(v_num - 50);
  END IF;
END proc_test;

case … when … end case 判断

CREATE OR REPLACE PROCEDURE proc_test(v_num IN NUMBER) AS
BEGIN
  case v_num
    when 1 then
      DBMS_OUTPUT.put_line(v_num);
    when 2 then
      DBMS_OUTPUT.put_line(v_num);
    when 3 then
      DBMS_OUTPUT.put_line(v_num);
    else
      null;
  end case;
END proc_test;

游标

之前整理的游标的知识

Cursor 型游标 (不能用于参数传递)

CREATE OR REPLACE PROCEDURE proc_test AS
  CURSOR c1 IS
    SELECT * FROM dat_trade;
BEGIN
  FOR x IN c1 LOOP
    DBMS_OUTPUT.put_line(x.id);
  END LOOP;
END proc_test;

SYS_REFCURSOR 型游标

该游标是 Oracle 预先定义的游标,可作出参数进行传递。

SYS_REFCURSOR 只能通过 OPEN 方法来打开和赋值

我们可以使用这种类似的游标来返回一个结果集:

CREATE OR REPLACE procedure proc_test(checknum   in number, -- 每次返回的数据量
    ref_cursor out sys_refcursor -- 返回的结果集,游标
    ) as
begin
  open ref_cursor for
    select *
      from (select * from dat_trade where state = 41 order by id)
     where rownum < checknum;
end proc_test;

SYS_REFCURSOR 中可使用四个状态属性:

  • (1). %NOTFOUND(未找到记录信息)
  • (2). %FOUND(找到记录信息)
  • (3). %ROWCOUNT(然后当前游标所指向的行位置)
  • (4). %ISOPEN(是否打开)
CREATE OR REPLACE PROCEDURE proc_test(checknum   IN NUMBER, -- 每次返回的数据量
    ref_cursor OUT sys_refcursor -- 返回的结果集,游标
    ) AS
  t_tmp table_name%ROWTYPE;
BEGIN
  OPEN ref_cursor FOR
    SELECT *
      FROM (SELECT * FROM table_name WHERE state = 41 ORDER BY id)
     WHERE ROWNUM < checknum;
  -- 循环游标
  LOOP
    FETCH ref_cursor
      INTO t_tmp;
    EXIT WHEN ref_cursor%NOTFOUND;
    -- DBMS_OUTPUT.put_line (t_tmp.id);
    UPDATE table_name SET state = 53 WHERE id = t_tmp.id;
    COMMIT;
  END LOOP;
  CLOSE ref_cursor;
END proc_test;

更多 Oracle 相关信息见 Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2016-11/136852.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3621字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7805253
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛NAS-12:开源笔记的进化之路,效率玩家的新选择

星哥带你玩飞牛 NAS-12:开源笔记的进化之路,效率玩家的新选择 前言 如何高效管理知识与笔记,已经成为技术...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级

让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级

让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级 大家好,我是星哥,之前写了一篇文章 自己手撸一...
开源神器组合!1Panel面板+Halo助你轻松打造个人/企业内容中心

开源神器组合!1Panel面板+Halo助你轻松打造个人/企业内容中心

开源神器组合!1Panel 面板 +Halo 助你轻松打造个人 / 企业内容中心 前言 大家好,我是星哥,之前...
告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

  告别 Notion 焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁” 引言 在数字笔记工...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞定

多服务器管理神器 Nexterm 横空出世!NAS/Win/Linux 通吃,SSH/VNC/RDP 一站式搞...
颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

  颠覆 AI 开发效率!开源工具一站式管控 30+ 大模型 ApiKey,秘钥付费 + 负载均衡全...
三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Android 的最优解?

  三大开源投屏神器横评:QtScrcpy、scrcpy、escrcpy 谁才是跨平台控制 Andr...
每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年0.99刀,拿下你的第一个顶级域名,详细注册使用

每年 0.99 刀,拿下你的第一个顶级域名,详细注册使用 前言 作为长期折腾云服务、域名建站的老玩家,星哥一直...
150元打造低成本NAS小钢炮,捡一块3865U工控板

150元打造低成本NAS小钢炮,捡一块3865U工控板

150 元打造低成本 NAS 小钢炮,捡一块 3865U 工控板 一块二手的熊猫 B3 工控板 3865U,搭...