滚雪球学Oracle[4.2讲]:PL/SQL基础语法

全文目录:

    • 前言
    • 一、PL/SQL基础语法
      • 1.1 变量声明
        • 变量声明示例:
    • 二、记录类型与集合类型的使用
      • 2.1 记录类型
        • 记录类型的定义与使用
      • 2.2 集合类型
    • 三、PL/SQL表与关联数组
      • 3.1 PL/SQL表(嵌套表)
        • 嵌套表的定义与使用
      • 3.2 关联数组
        • 关联数组的定义与使用
    • 四、集合操作:BULK COLLECT与FORALL
      • 4.1 BULK COLLECT
        • 使用BULK COLLECT的示例
      • 4.2 FORALL
        • 使用FORALL的示例
    • 五、总结与下期预告

前言

在上一篇文章【PL/SQL简介与环境设置】中,我们介绍了PL/SQL语言的基本概念及其运行环境的配置。PL/SQL(Procedural Language for SQL)是Oracle数据库的扩展语言,通过将过程化编程引入SQL,开发人员可以创建更加灵活和复杂的数据库操作程序。PL/SQL为处理复杂的业务逻辑提供了强大的工具,但在编写高效代码时,理解其基本语法和数据结构至关重要。

本期内容将详细探讨PL/SQL的基础语法,并深入解析记录类型与集合类型的使用。此外,介绍PL/SQL表和关联数组,展示如何使用BULK COLLECTFORALL进行批量数据处理,从而提升数据操作的效率。

在文章的结尾,我们将对下期内容【控制结构与循环】进行预告,继续学习PL/SQL中用于流程控制的结构化语法。

一、PL/SQL基础语法

PL/SQL是Oracle数据库独有的过程式语言,它的基本语法结构类似于其他编程语言,包含变量声明、控制语句、循环、异常处理等。PL/SQL块的基本结构如下:

DECLARE
  -- 声明部分(可选)
  v_employee_name VARCHAR2(100);
BEGIN
  -- 执行部分
  SELECT first_name INTO v_employee_name FROM employees WHERE employee_id = 100;
  DBMS_OUTPUT.PUT_LINE('Employee Name: ' || v_employee_name);
EXCEPTION
  -- 异常处理部分(可选)
  WHEN NO_DATA_FOUND THEN
    DBMS_OUTPUT.PUT_LINE('No employee found.');
END;

在此代码块中,DECLARE部分用于声明变量,BEGIN...END构成了主执行逻辑,而EXCEPTION部分处理可能发生的异常。

1.1 变量声明

PL/SQL允许使用各种数据类型声明变量。常见的数据类型包括:

  • NUMBER:用于表示整数和浮点数。
  • VARCHAR2:表示变长字符串。
  • DATE:表示日期和时间。
变量声明示例:
DECLARE
  v_emp_id NUMBER(6);
  v_emp_name VARCHAR2(100);
  v_hire_date DATE;
BEGIN
  -- 在这里可以使用这些变量
END;

变量必须在使用之前声明,并且每个变量都需要指定其数据类型。PL/SQL支持从表中获取数据并赋值给变量,如通过SELECT INTO语句。


二、记录类型与集合类型的使用

2.1 记录类型

记录类型(Record Type)是PL/SQL中用于存储一组不同类型数据的结构,类似于C语言中的结构体或其他编程语言中的对象。记录类型允许将表中的一行或多个列组合到一个变量中,便于操作多列数据。

记录类型的定义与使用

PL/SQL允许开发者自定义记录类型或基于表行定义记录类型:

  • 自定义记录类型

    DECLARE
      TYPE employee_record IS RECORD (
        emp_id employees.employee_id%TYPE,
        emp_name employees.first_name%TYPE,
        hire_date employees.hire_date%TYPE
      );
      v_emp_rec employee_record;
    BEGIN
      -- 使用记录类型获取一行数据
      SELECT employee_id, first_name, hire_date
      INTO v_emp_rec.emp_id, v_emp_rec.emp_name, v_emp_rec.hire_date
      FROM employees
      WHERE employee_id = 100;
      
      DBMS_OUTPUT.PUT_LINE('Employee: ' || v_emp_rec.emp_name);
    END;
    

    在此示例中,employee_record是一个自定义记录类型,存储了员工的employee_idfirst_namehire_date,并通过SELECT INTO语句将数据存入记录。

  • 基于表行的记录类型
    PL/SQL允许基于某个表的行定义记录类型,简化记录的声明:

    DECLARE
      v_emp_rec employees%ROWTYPE;
    BEGIN
      SELECT * INTO v_emp_rec FROM employees WHERE employee_id = 100;
      DBMS_OUTPUT.PUT_LINE('Employee: ' || v_emp_rec.first_name);
    END;
    

    在此示例中,v_emp_rec使用了employees%ROWTYPE,它自动匹配employees表中的列,使操作更简洁。

2.2 集合类型

集合是PL/SQL中用于存储同类型数据的结构。PL/SQL支持三种主要的集合类型:

  1. 嵌套表(Nested Table):类似于动态数组,可以存储无序的元素,且可以动态扩展。
  2. VARRAY(变长数组):具有固定大小的数组,元素是有序的。
  3. 关联数组(索引表):键值对结构,用作稀疏数组。

三、PL/SQL表与关联数组

3.1 PL/SQL表(嵌套表)

PL/SQL表(嵌套表)是一种灵活的集合类型,可以存储一组相同类型的数据。在PL/SQL中,可以使用嵌套表来处理多个数据值,尤其是在批量处理时非常有用。

嵌套表的定义与使用
DECLARE
  TYPE num_table IS TABLE OF NUMBER;
  v_numbers num_table := num_table(100, 200, 300);
BEGIN
  -- 访问嵌套表中的元素
  FOR i IN v_numbers.FIRST .. v_numbers.LAST LOOP
    DBMS_OUTPUT.PUT_LINE('Number: ' || v_numbers(i));
  END LOOP;
END;

在此示例中,定义了一个num_table类型的嵌套表,并将一些数字值存储在其中。通过FOR循环可以遍历集合中的所有元素。

3.2 关联数组

关联数组(Index-by Table)是键值对类型的集合。它使用数字或字符串作为索引,通过索引可以访问数组中的元素。

关联数组的定义与使用
DECLARE
  TYPE emp_salary_table IS TABLE OF NUMBER INDEX BY PLS_INTEGER;
  v_salaries emp_salary_table;
BEGIN
  -- 为关联数组赋值
  v_salaries(1001) := 5000;
  v_salaries(1002) := 6000;

  -- 访问关联数组中的值
  DBMS_OUTPUT.PUT_LINE('Salary of emp 1001: ' || v_salaries(1001));
END;

在此例子中,定义了一个关联数组emp_salary_table,并通过索引来存储和访问员工的薪资数据。关联数组非常适合需要根据键值快速查找数据的场景。


四、集合操作:BULK COLLECT与FORALL

4.1 BULK COLLECT

在PL/SQL中,BULK COLLECT用于将查询结果批量加载到集合中,从而减少SQL与PL/SQL之间的切换次数。这种方法非常适合大数据量的查询,能够显著提高性能。

使用BULK COLLECT的示例
DECLARE
  TYPE num_table IS TABLE OF NUMBER;
  v_emp_ids num_table;
BEGIN
  -- 使用BULK COLLECT将查询结果加载到集合中
  SELECT employee_id BULK COLLECT INTO v_emp_ids FROM employees WHERE department_id = 10;
  
  -- 遍历集合并输出结果
  FOR i IN v_emp_ids.FIRST .. v_emp_ids.LAST LOOP
    DBMS_OUTPUT.PUT_LINE('Employee ID: ' || v_emp_ids(i));
  END LOOP;
END;

在此示例中,BULK COLLECT用于将员工ID批量加载到v_emp_ids集合中,从而减少逐条查询的开销。

4.2 FORALL

FORALL是一种PL/SQL的控制结构,用于批量执行INSERTUPDATEDELETE语句。与常规的FOR循环相比,FORALL可以显著提高批量DML操作的性能。

使用FORALL的示例
DECLARE
  TYPE num_table IS TABLE OF NUMBER;
  v_emp_ids num_table := num_table(1001, 1002, 1003);
BEGIN
  -- 使用FORALL进行批量更新
  FORALL i IN v_emp_ids.FIRST .. v_emp_ids.LAST
    UPDATE employees SET salary = salary * 1.1 WHERE employee_id = v_emp_ids(i);
    
  DBMS_OUTPUT.PUT_LINE('Salaries updated.');
END;

在此示例中,FORALL用于批量更新多个员工的薪资,与逐行处理相比,FORALL的执行速度大大提高。


五、总结与下期预告

本期文章详细介绍了PL/SQL中的

基础语法,并深入探讨了记录类型集合类型的使用。我们学习了如何使用PL/SQL表与关联数组来处理批量数据操作,并通过BULK COLLECTFORALL实现了高效的数据处理。掌握这些技术对于提升PL/SQL代码的性能至关重要,尤其是在处理大量数据时。

在下一期内容中,我们将探讨PL/SQL中的控制结构与循环,继续深入学习PL/SQL的高级控制结构,从而编写更灵活、健壮的程序逻辑。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/886216.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【RADARSAT Constellation Mission(RCM)卫星星座简介】

RADARSAT Constellation Mission(RCM)卫星星座是加拿大太空局(CSA)的下一代C波段合成孔径雷达(SAR)卫星星座,以下是对其的详细介绍: 一、基本信息 发射时间:2019年6月…

在Linux系统安装Nginx

注意:Nginx端口号是80(云服务器要放行) 我的是基于yum源安装 安装yum源(下面这4步就好了) YUM源 1、将源文件备份 cd /etc/yum.repos.d/ && mkdir backup && mv *repo backup/ 2、下载阿里源文件 curl -o /etc/yum.repos.d/CentOS-Base.repo ht…

Adobe PR与AE的区别与联系(附网盘地址)

从事视频后期制作的小伙伴,对于PR(Premiere)和AE(After Effects)应该不会陌生。随着短视频的兴起,就连我们普通用户,拍摄完视频,都会去糟取精的剪辑一下,而PR正是一款功能…

【分布式微服务云原生】windows+docker+mysql5.7.44一主一从主从复制

目录 1. 主库设置2. 从库设置3. 验证主从复制内容汇总表格 摘要: 在Windows系统上通过Docker部署MySQL主从复制,以下是详细的步骤和命令,帮助你设置一主一从的MySQL复制环境。 1. 主库设置 步骤1:运行MySQL主库容器 docker run …

探索Python网络世界的利器:Requests-HTML库

文章目录 探索Python网络世界的利器:Requests-HTML库背景:为何选择Requests-HTML?什么是Requests-HTML?如何安装Requests-HTML?5个简单库函数的使用方法3个场景下库的使用示例常见Bug及解决方案总结 探索Python网络世界…

微服务nginx解析部署使用全流程

目录 1、nginx介绍 1、简介 2、反向代理 3、负载均衡 2、安装nginx 1、下载nginx 2、解压nginx安装包 3、安装nginx​编辑 1、执行configure命令 2、执行make命令 4、启动nginx 1、查找nginx位置并启动 2、常用命令 3、反向代理 1、介绍反向代理配置 1、基础配置…

【iOS】计算器的仿写

计算器 文章目录 计算器前言简单的四则运算UI界面事件的逻辑小结 前言 笔者应组内要求,简单实现了一个可以完成简单四则运算的计算器程序。UI界面则是通过最近学习的Masonry库来实现的,而简单的四则运算内容则是通过栈来实现一个简单的四则运算。 简单…

Halcon实用系列1-识别二维条码

在做项目时,之前使用的是某康的智能读码器,综合考虑成本,可通过相机拍照来读取图片的二维码,我这边用Halcon来实现。 Halcon代码如下: *创建模型 create_data_code_2d_model(Data Matrix ECC 200, [], [], DataCodeH…

5G NR物理信道简介

文章目录 NR 上行物理信道PRACHPUCCHPUSCH NR 下行物理信道PBCHPDCCHPDSCH NR 上行物理信道 PRACH PRACH(Physical Random Access Channel)物理随机接入信道,用于传导preamble 序列。PRACH 由循环前缀CP、前导序列和保护间隔三部分组成。 PUCCH PUCCH…

【AI大模型】深入Transformer架构:编码器部分的实现与解析(上)

目录 🍔 编码器介绍 🍔 掩码张量 2.1 掩码张量介绍 2.2 掩码张量的作用 2.3 生成掩码张量的代码分析 2.4 掩码张量的可视化 2.5 掩码张量总结 🍔 注意力机制 3.1 注意力计算规则的代码分析 3.2 带有mask的输入参数: 3.…

FOCShield v2.0.4原理图

1.FOCShield v2.0.4原理图,开源原文件用AD制作。用 AD09可以打开。 主要部分为 1.电机驱动芯片部分 2.电流采样部分

Windows 环境下安装 Anaconda 并适配到 PowerShell 的保姆级教程

Anaconda Anaconda 是一个流行的 Python 数据科学和机器学习平台,它包括了 Conda 包管理器、Python 以及数百个用于科学计算的库和工具。Anaconda 旨在简化包和环境管理,使得安装、更新和管理软件包变得容易,同时也能够轻松创建和切换不同的P…

大数据毕业设计选题推荐-民族服饰数据分析系统-Python数据可视化-Hive-Hadoop-Spark

✨作者主页:IT研究室✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

【Linux】命令管道

一、命名管道的介绍 之前的管道博客中介绍的是匿名管道,这个管道的应用的一个限制就是只能在具有公共祖先(具有亲缘关系)的进程间通信。 如果我们不想在不相关的进程之间交换数据,可以使用FIFO文件来做这项工作,他经常…

输入捕获模式测频率PWMI模式测频率占空比

前沿知识:TIM输入捕获-CSDN博客 输入捕获相关函数 // 初始化输入捕获单元 // ICInit是4个通道共用一个函数的,第二个结构体参数,可以用来配置具体是哪个通道。 void TIM_ICInit(TIM_TypeDef* TIMx, TIM_ICInitTypeDef* TIM_ICInitStruct);/…

【MAUI】CollectionView之 垂直网格

App主页或者导航页面中动态按钮的垂直网格布局 在 XAML 中,CollectionView 可以通过将其 ItemsLayout 属性设置为 VerticalGrid,在垂直网格中显示其项: <CollectionView ItemsSource="{Binding Monkeys}"ItemsLayout

TCP/UDP初识

TCP是面向连接的、可靠的、基于字节流的传输层协议。 面向连接&#xff1a;一定是一对一连接&#xff0c;不能像 UDP 协议可以一个主机同时向多个主机发送消息 可靠的&#xff1a;无论的网络链路中出现了怎样的链路变化&#xff0c;TCP 都可以保证一个报文一定能够到达接收端…

【YOLO学习】YOLOv2详解

文章目录 1. 概述2. Better2.1 Batch Normalization&#xff08;批归一化&#xff09;2.2 High Resolution Classifier&#xff08;高分辨率分类器&#xff09;2.3 Convolutional With Anchor Boxes&#xff08;带有Anchor Boxes的卷积&#xff09;2.4 Dimension Clusters&…

二分查找算法专题(1)

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a; 优选算法专题 目录 二分查找算法的介绍 704. 二分查找 34. 在排序数组中查找元素的第一个和 最后一个位置 35. 搜索插入位置 69. x的平…

力扣题解 983

大家好&#xff0c;欢迎来到无限大的判断&#xff0c;祝大家国庆假期愉快 题目描述&#xff08;中等&#xff09; 最低票价 在一个火车旅行很受欢迎的国度&#xff0c;你提前一年计划了一些火车旅行。在接下来的一年里&#xff0c;你要旅行的日子将以一个名为 days 的数组给出…