MogDB/openGauss 关于 PL/SQL 匿名块调用测试

一、原理介绍

PL/SQL(Procedure Language/Structure Query Language)是标准 SQL 语言添加了过程化功能的一门程序设计语言。

单一的 SQL 语句只能进行数据操作,没有流程控制,无法开发复杂的应用。PL/SQL 语言是结合了结构化查询与数据库自身过程控制为一体的强大语言。

1.PL/SQL 原理

PL/SQL 是一种块结构的语言,它将一组语句放在一个块中,一次性发送给服务器。

PL/SQL 引擎分析收到 PL/SQL 语句块中的内容,把其中的过程控制语句由 PL/SQL 引擎自身去执行,把 PL/SQL 块中的 SQL 语句交给服务器的 SQL 语句执行器执行。

PL/SQL 块发送给服务器后,先被编译然后执行,对于有名称的 PL/SQL 块(如子程序)可以单独编译,永久的存储在数据库中,随时准备执行。

PL/SQL 是一种块结构的语言,一个 PL/SQL 程序包含了一个或者多个逻辑块,逻辑块中可以声明变量,变量在使用之前必须先声明。

2.PL/SQL 特点

–与 SQL 紧密结合

–支持面向对象编程

–更好的性能

–可移植性

–安全性

3.语法结构

除了正常的执行程序外,PL/SQL 还提供了专门的异常处理部分进行异常处理

[DECLARE

--declaration statements] ①

BEGIN

--executable statements ②

[EXCEPTION

--exception statements] ③

END;

语法解析

① 声明部分:声明部分包含了变量和常量的定义。在此声明 PL/SQL 用到的变量,类型及游标,以及局部的存储过程和函数,

这个部分由关键字 DECLARE 开始,如果不声明变量或者常量,可以省略这部分。

② 执行部分:执行部分是 PL/SQL 块的指令部分,由关键字 BEGIN 开始,关键字 END 结尾。

所有的可执行 PL/SQL 语句都放在这一部分,该部分执行命令并操作变量。其他的 PL/SQL 块可以作为子块嵌套在该部分。

PL/SQL 块的执行部分是必选的。注意 END 关键字后面用分号结尾。

③ 异常处理部分:该部分是可选的,该部分用 EXCEPTION 关键字把可执行部分分成两个小部分,之前的程序是正常运行的程序,

一旦出现异常就跳转到异常部分执行。

4.PL/SQL 语句块的类型

1、匿名块

2、命名块

–①procedure 存储过程

–②function 函数

–③package 包

–④trigger 触发器

原本大家可能一提到 PL/SQL 就会想到 ORACLE,ORACLE 的 PL/SQL 很强大,它的匿名块调用以及有名块调用可以解决很多问题,在 MOGDB/openGauss 中,其实也有这样的功能,如下,是我针对 MOGDB/openGauss 匿名块的一些测试。

二、匿名块测试

1.普通匿名块调用

openGauss=# create table t1(a int ,b text);

CREATE TABLE

openGauss=# DECLARE

openGauss-# PRAGMA AUTONOMOUS_TRANSACTION;

openGauss-# BEGIN

openGauss$# raise notice 'Normal anonymous block printing.';

openGauss$# insert into t1 values(1,'I am lmj!');

openGauss$# END;

openGauss$# /

NOTICE: Normal anonymous block printing.

ANONYMOUS BLOCK EXECUTE

openGauss=# select * from t1;

a | b

---+-----------

1 | I am lmj!

(1 row)

2.匿名块和事务影响

启动一个事务后,执行一个自治事务匿名块,如果事务回滚,则匿名块不回滚。

openGauss=# truncate table t1;

TRUNCATE TABLE

openGauss=# START TRANSACTION;

START TRANSACTION

openGauss=# DECLARE

openGauss-# PRAGMA AUTONOMOUS_TRANSACTION;

openGauss-# BEGIN

openGauss$# raise notice 'an autonomous transaction anonymous block.';

openGauss$# insert into t1 values(1,'it will commit!');

openGauss$# END;

openGauss$# /

NOTICE: an autonomous transaction anonymous block.

ANONYMOUS BLOCK EXECUTE

openGauss=# insert into t1 values(1,'you will rollback!');

INSERT 0 1

openGauss=# rollback;

ROLLBACK

openGauss=# select * from t1;

a | b

---+-----------------

1 | it will commit!

(1 row)

3.外部匿名块和内部匿名块

其中外部匿名块是一个公共匿名块,而内部匿名块是一个自治事务匿名块,可以根据如下例子和第二个例子对比事务回滚和匿名块回滚

openGauss=# truncate table t1;

TRUNCATE TABLE

openGauss=# DECLARE

openGauss-# BEGIN

openGauss$# DECLARE

openGauss$# PRAGMA AUTONOMOUS_TRANSACTION;

openGauss$# BEGIN

openGauss$# raise notice 'just use call.';

openGauss$# insert into t1 values(1,'can you rollback!');

openGauss$# END;

openGauss$# insert into t1 values(2,'I will rollback!');

openGauss$# rollback;

openGauss$# END;

openGauss$# /

NOTICE: just use call.

ANONYMOUS BLOCK EXECUTE

openGauss=# select * from t1;

a | b

---+---

(0 rows)

4.匿名块直接执行自治事务匿名块并引发异常

openGauss=# DECLARE

openGauss-# PRAGMA AUTONOMOUS_TRANSACTION;

openGauss-# res int := 0;

openGauss-# res2 int := 1;

openGauss-# BEGIN

openGauss$# raise notice 'just use call.';

openGauss$# res2 = res2/res;

openGauss$# END;

openGauss$# /

NOTICE: just use call.

ERROR: ERROR: division by zero

CONTEXT: PL/pgSQL function inline_code_block line 7 at assignment

匿名块执行错误,会报出异常

5.异常捕获

在执行期间引发异常后,将捕获匿名块,如下所示,在执行错误后,抛出 autonomous throw exception 提示

openGauss=# DECLARE

openGauss-# PRAGMA AUTONOMOUS_TRANSACTION;

openGauss-# res int := 0;

openGauss-# res2 int := 1;

openGauss-# BEGIN

openGauss$# raise notice 'error catch.';

openGauss$# res2 = res2/res;

openGauss$# EXCEPTION

openGauss$# WHEN division_by_zero THEN

openGauss$# raise notice 'autonomous throw exception.';

openGauss$# END;

openGauss$# /

NOTICE: error catch.

NOTICE: autonomous throw exception.

ANONYMOUS BLOCK EXECUTE

MogDB/openGauss关于PL/SQL匿名块调用测试的更多相关文章

  1. 同样的一句SQL语句在pl/sql 代码块中count 没有数据,但是直接用SQl 执行却可以count 得到结果

    pl/sql 代码块: SELECT count(distinct t2.so_nbr) INTO v_count2 FROM KFGL_YW_STEP_qd t2 WHERE t2.partitio ...

  2. PL/SQL精明的调用栈分析

    PL/SQL精明的调用栈分析 原文:http://www.oracle.com/technetwork/issue-archive/2014/14-jan/o14plsql-2045346.html ...

  3. SQLPLUS执行PL/SQL语句块

    1.首先登录Oracle HR schema: 2.对于PL/SQL程序,分号表示语句的结束:而使用 "."  号表示整个语句块的结束,也可以省略.按回车键后,该语句块不会执行,即 ...

  4. oracle 中使用 pl/sql代码块

    1.写匿名块,输入三角形三个表的长度.在控制台打印三角形的面积. declare -- (p=(a+b+c)/2) --声明三角形的面积 三条边 的 v_a number (10,2):=&n ...

  5. PL/SQL程序中调用Java代码(转)

    主要是学习PL/SQL调用JAVA的方法. 平台:WINDOWS 1.首先使用IDE写好需要调用的java代码,再添加"create or replace and compile java ...

  6. PL/SQL编程-块编程

    (1). 简单分类                           |————过程(存储过程)                           |                        ...

  7. PL/SQL语句块提高1+case语句

    set serveroutput on; declare --默认值的bianliang v_a ; -- v_b integer; --用stud.id 的类型 v_id stud.id%type; ...

  8. pl/sql 语句块循环语句

    ---基本循环declarev1 number(2) :=1;begin loop dbms_output.put_line(v1); v1:=v1+1; exit when v1>10; -- ...

  9. PL/SQL编程基础(一):PL/SQL语法简介(匿名PL/SQL块)

    PL/SQL PL/SQL是Oracle在关系数据库结构化查询语言SQL基础上扩展得到的一种过程化查询语言. SQL与编程语言之间的不同在于,SQL没有变量,SQL没有流程控制(分支,循环).而PL/ ...

  10. Oracle数据库之PL/SQL异常处理

    Oracle数据库之PL/SQL异常处理 异常指的是在程序运行过程中发生的异常事件,通常是由硬件问题或者程序设计问题所导致的. PL/SQL程序设计过程中,即使是写得最好的程序也可能会遇到错误或未预料 ...

随机推荐

  1. Program type already present: com.xxx

    该错误是由于工程中存在着相同的类导致(包名与类名都相同),有可能是不同的依赖中有着相同的类,全局搜索该类便可得知

  2. 影刀rpa:第二个项目学习心得

    教程有说到元素的关联操作,教程说自上而下的html路径,一时之间没弄清楚,索性就去看了下网页的html源码,才弄清楚到底是咋回事: 我是先选中了列表子元素的价格字段,选择两次以后就能选择到所有列表子元 ...

  3. BUUCTF—Crypto(完结版本—_—)

    BUUCTF-Crypto 1.一眼就解密 考点:base64 我的解答: 字符串后面的等号,看来是base大家族,由字母和数字范围来看是base64,不管了,先扔CyberCher,仙女魔法棒变出f ...

  4. SpringCloud Sentinel使用

    1. 简介 Sentinel 是面向分布式服务架构的流量控制组件,主要以流量为切入点,从限流.流量整形.熔断降级.系统负载保护.热点防护等多个维度来帮助开发者保障微服务的稳定性.替换原先Hystrix ...

  5. Java 面向对象的特征一: * 封装与隐藏

    1 * @ 面向对象的特征一: 2 * 封装与隐藏 3 * 创建一个类的对象以后,我们可以通过"对象.属性"的方式,对 4 * 对象的属性进行赋值,这里,赋值操作要受到属性的数据类 ...

  6. welearn平台答案 大学英语 视听说 综合教程

    打开页面 1. F12 2. ctrl+shift+c 3. 鼠标移动到选项位置 4. 带data-solution的就是答案

  7. 一文搞懂如何自己写一个Python库

    一文搞懂如何自己写一个Python库 你是否曾想过为自己的Python项目编写一个库,以便在不同项目中重复使用代码? 并且能在PyPI仓库中发布,并通过pip install 库名来安装使用 编写Py ...

  8. ConcurrentHashMap的put方法

    使用JDK8 源码: public V put(K key, V value) { return putVal(key, value, false); } /** Implementation for ...

  9. python AI应用开发编程实战 大模型实战基础(数据存储类型列表与字典)(二)

    大模型开发中,需要和自己的业务融合,我们要对自己的数据处理,熟悉外理excle  word  pdf 数据然后处理后可以放到向量数据库,或者直接Assistants API传到大模型引用,不管怎么样数 ...

  10. Java面向对象(中)--super/多态/向下转型/equals/toString/包装类/单元测试工具

    java对象 方法重写 子类继承父类以后,可以对父类同名同参数的方法,进行覆盖操作 重写后,当创建子类对象以后,通过子类对象调用子父类中同名同参数的方法时,执行的是子类重写父类的方法. 如何区分方法重 ...