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. 【Azure Redis】Redis-CLI连接Redis 6380端口始终遇见 I/O Error

    问题描述 使用Redis-cli连接Redis服务,因为工具无法直接支持TLS 6380端口连接,所以需要使用 stunnel 配置TLS/SSL服务.根据文章(Linux VM使用6380端口(SS ...

  2. 【Azure 应用服务】App Service For Linux 环境中,如何从App Service中获取GitHub私有库(Private Repos)的Deploy Key(RSA key)呢?

    问题描述 为App Service For Linux配置CI/CD,源代码在GitHub私有库中,在发布时候报错 Cannot find SourceControlToken with name B ...

  3. Navicat Premium15 解决只能显示前1000条记录问题

    Navicat Premium15 解决只能显示前1000条记录问题 最近使用Navicat Premium15图形化界面操作MySQL的数据库,发现在超过1461条记录的表里,只能显示前1000条, ...

  4. 芯片公司Dialog产品调研简报

    一 公司简介: Dialog半导体有限公司的总部位于伦敦,设有一个全球销售.研发和营销部.2013年,公司实现了9.10亿美元的营业收入,是欧洲增长速度最快的公共半导体公司之一.   二 芯片型号: ...

  5. 35_音视频播放器_seek&暂停

    目录 一.实现seek功能 二.解决点击seek操作时会出现画面快速闪过 三.实现暂停功能 3.1.音频暂停 3.2.视频暂停 一.实现seek功能 我们主要是使用ffmpeg的av_seek_fra ...

  6. DL基础补全计划(四)---对抗过拟合:权重衰减、Dropout

    PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 前置说明   本文作为本人csdn blog的主站的备份.(Bl ...

  7. 恶意软件开发(三)经典DLL注入流程

    什么是dll注入? DLL注入允许将外部DLL文件加载到进程中并运行其中的代码.DLL(动态链接库)是一种可重用的代码库,它包含在多个程序中使用的函数.类.变量和其他程序代码.DLL注入技术可以通过将 ...

  8. TP6框架--EasyAdmin学习笔记:项目上线

    这是我暂时写EasyAdmin的最后一章,给大家分享下项目上线的全过程,希望对大家有所帮助,废话不多说,直接上内容 服务器我选用的是阿里云,上线时我使用的是宝塔面板来进行部署,如果你是新手,并不熟练服 ...

  9. replace小数点后保留2位

    小数点后保留2位 网上一堆小数点保留2位正则,但大部分都是直接copy,未解决0101和以.开头的这种情况 网上写法 obj.value = obj.value.replace(/[^\d.]/g,& ...

  10. Oracle 视图创建自增ID

    select ROW_NUMBER() over (order by sysdate()) as id