当前位置: 首页 > news >正文

Oracle 遍历变量游标

背景

        由于我们的数据库系统中的游标特别多,DBA让我们优化,减少游标的使用。

  • 电脑系统:windows
  • 数据库:Oracle
  • 数据库图形化界面工具:Toad,DBeaver(我測試的時候用的)
  • 记录日期:2023-09-04

具体实现

        在我目前所了解到的数据库中能够实现遍历的有游标(CURSOR)、FOR循环两种方式,不过都要跟loop...end loop;联合使用。

        我这里都用了匿名函数,这些都是可以直接执行的,DBeaver可通過【Ctrl+Shift+O 或者,您可以通过单击“查看服务器输出”】

游标
  • 优点
    • 可随时打开关闭使用,可全局可局部
  • 缺点
    • 查询了多少变量,就要承接多少
-- 這是一個匿名循環,可以直接執行DECLAREvar_text   VARCHAR(100);var_value1 VARCHAR(100);var_value2 VARCHAR(100);CURSOR GET_VALUE ISSELECT 'value1', 'value2' FROM dualUNION ALLSELECT 'value11', 'value22' FROM dual;BEGINOPEN GET_VALUE;DBMS_OUTPUT.PUT_LINE('CURSOR循環開始');LOOPBEGINFETCH GET_VALUE INTO var_value1, var_value2;EXIT WHEN GET_VALUE%NOTFOUND;-- var_text:=var_text||''''||var_value1||'''';var_text := var_value1;DBMS_OUTPUT.PUT_LINE(var_value1);/** * 具體實現* */END;END LOOP;CLOSE GET_VALUE;
END;
FOR
  • 优点 
    • 类似代码中的foreach(x in collection)循环,取用也与foreach一样,取用方便
  • 缺点
    • 主要用于局部
    • 像from dual这种的要给定栏位,不然会报错,如果是你自己建的表,一般就不会报错
-- 循环
DECLAREvar_text   VARCHAR(100);var_value1 VARCHAR(100);var_value2 VARCHAR(100);
BEGINDBMS_OUTPUT.PUT_LINE('FOR循环开始');FOR x IN (SELECT 'value1' value1, 'value2' value2, 'value3', 'value4', 'value5' FROM dualUNION ALLSELECT 'value111', 'value222', 'value333', 'value444', 'value555' FROM dualUNION ALLSELECT 'value911', 'value922', 'value933', 'value944', 'value955' FROM dual)LOOPvar_value1 := x.value1;var_value2 := x.value2;DBMS_OUTPUT.PUT_LINE(var_value1);EXIT WHEN var_value2 = 'value222';-- IF var_value1 LIKE 'US%' THEN-- CONTINUE;END LOOP;
END;

总结

        那些优缺点都是我自己用的时候感觉的,这些东西其实有时候也看你如何使用,也有可能是我还没发现好的用法,仅供大家参考。

http://www.lryc.cn/news/155968.html

相关文章:

  • C++11新特性① | C++11 常用关键字实战详解
  • VUE3学习小记(2)- ref 与 reactive
  • 基于单片机的万年历温度无线传输控制系统系统
  • ElementUI浅尝辄止19:Badge 标记
  • nginx两台负载均衡服务器之间使用keepalived实现高可用
  • 如何将Express项目部署到Vercel
  • Java作业3
  • ARM编程模型-寄存器组
  • C++ string
  • 百亿级访问量,如何做缓存架构设计
  • (数字图像处理MATLAB+Python)第十一章图像描述与分析-第三、四节:几何表述和形状描述
  • 20230901工作心得:IDEA列操作lambda表达式加强版用法
  • macOS Sonoma 14beta 7(23A5337a)更新发布,附黑/白苹果系统镜像
  • QT基础教程之九Qt文件系统
  • OpenCV(十八):图像直方图
  • mac pro 查看隐藏文件夹
  • 软件测试/测试开发丨Selenium 高级定位 Xpath
  • 各类注意力机制Attention——可变形注意力
  • 桥接模式:连接抽象与实现
  • 同步推送?苹果计划本月推出 iOS17和iPadOS17,你的手机支持吗?
  • 方案展示 | RK3588开发板Linux双摄同显方案
  • 数据库-多表设计
  • 一个简单的文件系统(MinixFS)实现解析
  • 地图投影-2亚当斯方形
  • atcoder库中类欧(类欧几里得算法)floor_sum用法
  • 后端面试话术集锦第 十一 篇:mybatis面试话术
  • SpringBoot运维实用篇、打包、运行、高级配置、多环境开发、日志
  • springdoc-openapi-ui 整合 knife,多模块分组,脚手架
  • 04-MySQL02
  • 实现跨境电商测评和采退、LU卡、LU货最安全的系统方案