Oracle基础-PL/SQL编程 备份

1、PL/SQL简介

 PL/SQL块结构

约定:为了方便,本文后面把PL/SQL简称PL。

        PL程序都是以块(BLOCK)为基本单位,整个PL块分三部分:声明部分(使用DECLARE开头)、执行部分(以BEGIN开头)和异常处理部分(以EXCEPTION开头)。其中执行部分是必须的,其他两个部分可选。无论PL的代码量有多大,其基本结构都是由这三部分组成。标准的PL语法格式如下:

[DECLARE]

        --   声明部分,可选

BEGIN

        --  执行部分,必须

[EXCEPTION]

        --  异常处理,可选

接下来对PL块的三个部分进行详细说明:

(1)声明部分由关键字DECLARE开始,到BEGIN关键字结束。在这部分可以声明PL程序块中所用到的变量、常亮和游标等。需要注意的是:在某个PL块中声明的内容只能在当前块中使用,而在其他的PL中无法引用。

(2)执行部分以关键字BEGIN开始,它的结束方式通常有两种。如果PL块中的代码在运行时出现异常,则执行完异常处理部分的代码就结束;如果没有使用异常处理或PL未出现异常,则以END关键字结束。执行部分是整个PL程序块的主体,主要的逻辑控制和运算都在这部分完成,所以在执行部分可以包含多个PL语句和SQL语句。

(3)异常处理部分以关键字EXCEPTION开始,在该关键字所包含的代码执行完毕后,整个PL块也就执行结束了。在执行PL代码的过程中,可能会产生一些意想不到的错误,比如除数为零,空值参与运算等,这些错误都会导致程序中断运行。这样程序设计人员就可以在异常处理部分通过编写一定量的代码来纠正错误或者给用户提供一些错误信息提示,甚至将各种数据操作回退到异常产生之前的状态,以备重新运行代码块。另外,对于可能出现的多种异常情况,用户可以使用WHEN THEN语句来实现多分支判断,然后在每个分支下通过编写代码来处理相应的异常。

        对于PL块中的语句,需要指出的是:每一条语句都必须以分号结束,每条SQL语句可以写成多行的形式,同样必须使用分号来结束。另外,一行中也可以有多条SQL语句,但是他们之间必须以分号分隔。

【例1.1】定义一个PL,计算两个整数的和与这两个整数的差的商。

set serveroutput on;
declarea int := 100;b int := 200;c number;beginc := (a+b)/(a-b);dbms_output.put_line(c);exceptionwhen zero_divide thendbms_output.put_line('除数不能为零');end;/

3791b99968ca43fb846a847c5fc72668.png

 在上面的代码中,首先使用"set serveroutput on"命令来实现在服务端显示执行结果;然后使用declare关键字声明了3个变量,其中,前两个为int变量a和b的初始值分别为100,200;最后在PL块的执行部分计算,并调用"dbms_output.put_line(c)"输出。为了防止除数为0,还设置了异常处理部分。若发生除数为零的情况,则代码块通过调用dbms_output.put_line('除数不能为零'),向用户提示。如

f2ed3df7bce7441b9a891a31ab270b9c.png

2、数据类型、变量和常量

2.1 概述

        数据类型本质上是一种用于描述数据存储的内存结构,用它来决定变量中所存储数据的类型,而变量本质上是一种用名称进行识别的标示符号,它可以存储不同类型的数据。根据不同的数据类型,定义不同名称的变量,这样就可以存储不同类型的数据。变量在程序运行的过程中,其值可以发生变化,与变量对应的就是常量,常量是指在程序运行的过程中,值不会发生变化。

2.2 基本数据类型

        PL有多种数据类型,这些数据类型能够满足在编写PL程序过程中定义变量和常量。

        2.2.1 数值类型

                数值类型主要包括NUMBER、PLS_INTEGER和BINARY_INTEGER三种基本类型。其中,NUMBER变量可以存储整数或浮点数,而PLS_INTEGER和BINARY_INTEGER只能存储整数。

                NUMBER 类型还可以通过number(P,S)的形式来格式化数字。其中,P表示精度,S表示刻度范围。精度是指数值中所有有效数字的个数,而刻度范围是指小数点右边小数位的个数,其中P和S都是可选的。

                【例2.2.1.1】声明一个精度为9,刻度范围是2的表示金额的变量Num_Money,代码如下。

        

Num_Money NUMBER(9,2);

PL还提出“子类型”的概念,子类型就是与NUMBER类型等价的类型别名,甚至可以说是NUMBER类型的多种命名形式,这些等价的子类型主要包括DEC,DECIMAL,DOUBLE,INTEGER,INT,NUMERIC,SMALLINT,BINARY_INTEGER,PLS_INTEGER等。

        2.2.2 字符类型

                字符类型主要包括VARCHAR2,CHAR,LONG,NCHAR,NVARCHAR2等,这些类型的变量可以用来存储字符串或字符数据。

                1、VARCHAR2

                PL语言中的VARCHAR2与数据库类型中的VARCHAR2类似,可以用来存储可变长度的字符串,声明语法格式为:

                VARCHAR2(maxlength)

                maxlength表示可以存储字符串的最大长度,这个参数值在定义变量时必须给出(因为VARCHAR2类型没有默认的最大长度),maxlength最大值是32767.

                注意:数据库类型的VARCHAR2的最大长度是4000字节,所以一个长度大于4000字节的PL类型VARCHAR2变量不可以赋值给数据库中的VARCHAR2变量,只能赋值给LONG类型的数据库变量。

                2、CHAR

                char 类型表示指定长度的字符串,其语法格式如下:

                CHAR(maxlength)

                maxlength指可存储字符串的最大长度,以字节为单位,最大32767字节,CHAR类型的默认最大长度是1。与VARCHAR2不同,maxlength可以不指定,默认为1。如果赋值CHAR类型的指不足maxlength,则会在后面用空格补全,这也是不同VARCHAR2的地方。

                注意:数据库类型的CHAR最大只有2000字节,所以如果PL中CHAR类型变量的长度大于2000字节,则不能赋给数据库中的CHAR。

                3、LONG

                LONG类型表示一个可变的字符串,最大长度是32767,而数据库类型的LONG最大长度为2GB,所以几乎任何字符串都可以赋值给它。

                4、NCHAR和NVARCHAR2

                NCHAR和NVARCHAR2类型是PL 8.0以后才加入的类型,它们的长度要根据各国字符集来确定,只能具体情况具体分析。

        2.2.3 日期类型

                日期类型只有一种DATE类型,用来存储日期和时间,DATE类型的存储空间是7个字节,分别使用一个字节存储世纪、年、月、日、小时、分、秒。

        2.2.4 布尔类型

                布尔类型也只有一种BOOLEAN,主要用户程序的流程控制和业务逻辑判断,其值可以使TRUE,FALSE,NULL。

2.3 特殊数据类型

        2.3.1 %TYPE类型

        使用%TYPE关键字可以声明一个与指定列相同的数据类型,它通常紧跟在指定列名的后面。

        【例2.3.1.1】声明一个与emp表中job列的数据类型完成相同的变量var_job

        

declarevar_job emp.job%TYPE;

        使用%TYPE定义变量有两个好处:第一,用户不必查询表中各个列的数据类型,就可以确保所定义的变量能够存储检索的数据;第二,如果对表中已有列的数据类型进行修改,则不必考虑对已定义的变量所使用的的数据类型进行更改,因为%TYPE类型的变量会根据列的实际类型自动调整自身的数据类型。

        【例2.3.1.2】使用%TYPE类型的变量输出emp表中编号为7369的员工名称和职务信息

                

SQL> set serveroutput on
SQL> declare 2      var_ename emp.ename%TYPE;3      var_job   emp.job%TYPE;4      begin5           select ename,job 6           into var_ename,var_job7           from emp8           where empno = 7369;9           dbms_output.put_line(var_ename || '的职务是' || var_job);10     end;11  /

30aa49a10ce140748f3b367e897c3806.png

在上面的代码中使用into子句,它位于select子句的后面,用于设置将从数据库检索的数据存储到哪个变量中。

注意:由于into子句中的变量只能存储一个单独的值,所以要求select子句只能返回一行数据,这个由where子句进行了限定,如果select子句返回多行数据,则代码运行后会返回错误信息 

        2.3.2 RECORD类型

        RECORD称为记录类型,使用该类型的变量可以存储由多个列值组成的一行数据,在声明记录类型变量之前,首先需要定义记录类型,然后才可以声明记录类型的变量。记录类型是一种结构化的数据类型,它使用type语句进行定义,在记录类型的定义结构中包含成员变量及其数据类型,语法:

        type record_type is record

        (

                var_member1 data_type [not null] [:=default_value],

                ...

                var membern data_type [not null] [:=default_value]

        )

        record_type:表示要定义的记录类型名称

        var_member1:表示该记录类型的成员变量名称。

        data_type:表示成员变量的数据类型

        【例2.3.2.1】声明一个记录类型emp_type,然后使用该类型的变量存储emp表中的一条记录信息,并输出。

set serveroutput on;
SQL> declare2      type emp_type is record3      (4           var_name varchar2(20),5           var_job varchar2(20),6           var_sal number7      );8      empinfo emp_type;9      begin10          select ename,job,sal into empinfo11          from emp12          where empno = 7369;13          dbms_output.put_line('员工' || empinfo.var_name || '的职务是' || empinfo.var_job ||',工资是' || empinfo.var_sal);14          end;15  /

1e558d9fb1ee4c7b9b351928728e0cbb.png

 2.3.3 %ROWTYPE类型

%rowtype 类型变量结合了“%type”和“record”变量的优点,它可以根据数据表中行的结构定义一种特殊的数据类型,用来存储从数据表中检索到的一行数据。语法:

rowVar_name table_name%rowtype;

rowVar_name:表示可以存储一行数据的变量名

table_name:指定的表名

【例2.3.3.1】声明一个%ROWTYPE类型的变量rowVar_emp,然后使用该变量存储emp表中的一行数据。

set serveroutput on;
SQL> declare2      rowVar_emp emp%rowtype;3      begin4        select * into rowVar_emp from emp where empno = 7369;5        dbms_output.put_line('员工'||rowVar_emp.ename || '的编号是' || rowVar_emp.empno ||',职务是' || rowVar_emp.job);6        end;7  /

952e6f3cb53044b090423121c68c01bc.png

 2.4 定义变量和常量

        2.4.1 定义变量

        变量是指其值在程序运行过程中可以改变的数据存储结构,定义变量必须的元素就是变量名和数据类型,另外还有可选择的初始值,格式如下:

<变量名><数据类型>[(长度) := <初始值>];

      可见,与许多面向对象的编程语言不通,PL中的变量定义要求变量名在数据类型的前面,而不是后面;语法中的长度和初始值是可选项,根据实际情况而定。

【例2.4.1.1】定义一个用户存储国家名称的可变字符串变量var_country,该变量的长度是50,并且该变量的初始值是"中国",代码如下:

var_country varchar2(50) := '中国';

        2.4.2 定义常量

        常量是指其值在程序运行过程中不可改变的数据存储结构,定义常量必须的元素包括常量名、数据类型、常量值和constant关键字,格式如下:

感谢关注,未完待续~~~~

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数字人视频合成平台推荐

数字人讲解视频和全景作品的结合是一种全新的数字交互方式&#xff0c;可为用户提供更加直观和具有沉浸感的内容展示和交互体验&#xff0c;从而适用于诸如旅游、展览、博物馆、教育培训、泛房地产、以及娱乐和文化等应用场景。 当前数字人合成视频技术已经发展至日益成熟的阶…

Redission--分布式锁

Redission的锁的好处 Redission分布式锁的底层是setnx和lua脚本(保证原子性) 1.是可重入锁。 2.Redisson 锁支持自动续期功能&#xff0c;这可以帮助我们合理控制分布式锁的有效时长&#xff0c;当业务逻辑执行时间超出了锁的过期时间&#xff0c;锁会自动续期&#xff0c;避免…

学术论文写作

学术论文写作 摘自复旦张军平老师的书籍&#xff1a;高质量读研&#xff1a;教你如何写论文、做科研 标题 标题&#xff1a;1.明确研究内容&#xff1b;2.吸引眼球 摘要 字数&#xff1a;期刊&#xff08;300字左右&#xff09;、会议&#xff08;150字左右&#xff09;、毕…

python之while循环

while 循环是一种前测试循环结构&#xff0c;意味着在每次循环开始时先检查条件是否为真&#xff0c;如果为真&#xff0c;则执行循环体中的代码&#xff0c;然后再次检查条件。只有当条件为假时&#xff0c;循环才会终止。 通过结合实际问题和 while 循环&#xff0c;我们可以…

SSL通配符证书怎么选?看这里

通配符证书&#xff0c;作为一种特殊的数字证书类型&#xff0c;以其独特的优势在网络安全领域扮演着重要角色。相较于传统的单一域名证书&#xff0c;通配符证书能够为同一主域名下的所有子域名提供安全保护&#xff0c;显著提升管理效率&#xff0c;简化证书部署流程&#xf…

LandCover数据介绍与下载

一、LC介绍 土地覆盖&#xff08;Land Cover&#xff0c;LC&#xff09;是自然营造物和人工建筑物所覆盖的地表诸多要素的综合体。土地覆盖指地表所属的植被覆盖物(森林、草原、耕作植被等)或非植被覆盖物(冰雪、建筑物等)的具体类型&#xff0c;侧重描述地球表面的自然属性&a…

02 - 全加器和加法器

---- 整理自B站UP主 踌躇月光 的视频 1. 全加器 用门电路实现两个二进制数相加并求出和的组合线路&#xff0c;称为一位全加器。一位全加器可以处理低位进位&#xff0c;并输出本位加法进位。全加器比半加器多了一位进位。 1.1 实验 1&#xff1a;通过两个半加器设计全加器 1.…

IDEA无法连接虚拟机中的Redis的解决方案,无法连接Jedis,无法ping通虚拟机的解决方案

首先&#xff0c;笔者先说明一下自身的情况&#xff0c;怎么连接都连不上&#xff0c;网上的教程全部都看了一遍&#xff0c;基本上没用得上的&#xff0c;这篇文章里面的解决方案包括了笔者能在网上找到了最全面的办法总结&#xff0c;最后终于是连上了 目录 一.连接Jedis出错…

Linux初学(十一)中间件

一、web服务 1.1 中间件简介 中间件其实就是一类软件&#xff0c;中间件的作用是让用户可以看到一个网页 总结&#xff1a;客户端可以向服务端发送请求&#xff0c;服务器端会通过中间件程序来接收请求&#xff0c;然后处理请求&#xff0c;最后将处理结果返回给客户端 1.2 中…

自动驾驶的世界模型:综述

自动驾驶的世界模型&#xff1a;综述 附赠自动驾驶学习资料和量产经验&#xff1a;链接 24年3月澳门大学和夏威夷大学的论文“World Models for Autonomous Driving: An Initial Survey”。 在快速发展的自动驾驶领域&#xff0c;准确预测未来事件并评估其影响的能力对安全性…

SQL面试题(1)连续登陆问题

​ 轻松一点&#xff0c;写一些SQL面试题系列&#xff0c;今天从连续登陆问题开始。连续登陆无疑是数据开发面试高频面试题&#xff0c;但遇到本人面试可能并不会出现这个面试题&#xff0c;一般我会根据实际开发场景出具SQL场景题目&#xff0c;且会设计成从浅入深考察应聘者的…

C++ 2024-4-2 作业

1.模板类实现顺序栈 #include <iostream> #define MAX 8 using namespace std; template<typename T> class stack {T data[MAX];int top; public:stack():top(-1){}bool empty_stack();bool full_stack();void push_stack(T data);void pop_stack();void show();…

OpenMLDB vs Redis 内存占用量测试报告

1. 背景 OpenMLDB 是一款开源的高性能全内存 SQL 数据库&#xff0c;在时序数据存储、实时特征计算等方面都有很多创新和优化。Redis 是业界最流行的内存存储数据库&#xff0c;广泛应用于缓存等高性能在线场景。虽然二者应用场景不尽相同&#xff0c;但作为都是使用内存作为存…

docker容器之etcd安装

一、etcd介绍 1、etcd是什么 etcd是CoreOS团队于2013年6月发起的开源项目&#xff0c;它的目标是构建一个高可用的分布式键值(key-value)数据库。 2、etcd特点 简单的接口&#xff0c;通过标准的HTTP API进行调用&#xff0c;也可以使用官方提供的 etcdctl 操作存储的数据。…

使用Vue实现CSS过渡和动画

01-初识动画和过渡 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>使用vue实现css过渡和动画&l…

MMU关闭时Cache的缓存策略是怎样的

快速链接: 【精选】ARMv8/ARMv9架构入门到精通-[目录] &#x1f448;&#x1f448;&#x1f448; 在学习MMU章节时&#xff0c;我们发现在页表的entry中&#xff0c;BIT[4:2]指向了MAIR寄存器&#xff0c;该寄存器描述了内存属性&#xff0c;其实就是cache的缓存策略属性&#…

一些常见的k8s问题和答案

什么是 Kubernetes&#xff08;K8s&#xff09;&#xff1f; Kubernetes是一个开源的容器编排平台&#xff0c;用于自动化部署、扩展和管理容器化应用程序。由多个组件组成&#xff0c;每个组件都有不同的作用和功能。以下是Kubernetes的主要组件及其作用&#xff1a; kube-ap…

ABAP 去除小数掉

有时我们需要将数字类型转换成字符型&#xff0c;但后面存在小数点为零的&#xff0c;以下方法可去掉。 DATA:QTY TYPE P DECIMALS 2,ZQTY TYPE C LENGTH 20,Q1 TYPE STRING, Q2 TYPE STRING,TAB_C TYPE C LENGTH 20. QTY 2. IF QTY <> 0. ZQTY QTY. CONDENSE ZQ…

高性价比的挂耳式耳机哪个好用?五大高口碑品牌深度测评严选!

入耳式耳机虽然普及度极高&#xff0c;但其缺点也不容忽视。首先&#xff0c;长时间佩戴可能导致耳朵不适&#xff0c;甚至影响听力健康。其次&#xff0c;入耳式耳机往往因为隔音效果过好&#xff0c;导致用户与周围环境脱节&#xff0c;失去了一定的生活便利性。相比之下&…

《书生·浦语大模型全链路开源开放体系》学习笔记

书生浦语大模型全链路开源开放体系-学习笔记 大模型成为发展通用人工智能的重要途径专用模型通用大模型 书生大模型开源历程InternLM2回归语言建模的本质主要亮点性能全方位提升强大的内生计算能力 从模型到应用典型流程全链条开源开放体系数据数据集获取预训练微调XTuner 评测…