存储过程(Stored Procedure)是一组已经事先编译好、能完成特定功能的 SQL 语句集
合,是一个独立的数据库对象。存储过程类似于高级语言中的函数,可被用户的应用程序
调用、执行。不同的是,存储过程经过编译后存放在服务器端,这为开发 C/S(客户端/
服务器)和 B/S(浏览器/服务器)应用程序提供了强有力的支持。由于存储过程是已经编
译好的代码,所以执行时不必再次进行编译,从而提高了程序的执行效率。
SPL(Stored Procedure Language)是在 GBase 8s 中提供的一种流程控制(分支和循环)
的 SQL,是对标准 SQL 的扩充,用于编写存储过程。存储过程包括 SPL 过程(没有返回值)和 SPL 函数(有返回值)。存储过程将在创建时被解析和优化,它以可执行的方式保存在 系统表中。
存储过程有以下优点:
1.模块化
类似于高级语言中的函数,存储过程一旦建立就可由不同用户利用 SPL 编写的程序调用,使代码的复用性提高,减少代码量。
2.提高性能
存储过程在创建时就进行了编译并存储在服务器中,以后对它的任何调用都不需再进行编译。因此存储过程的这种一次编译、多次执行的特点大大提高了程序执行的速度及性能。
3.减少网络流量
存储过程经过编译存储于服务器,数据的处理和操作均在服务器端进行。调用时只需将存储过程的名称以及参数传递给服务器,不用每次访问都传递很长的 SPL 语句段,从而降低了网络传输的开销。
4.提高安全性
存储过程可以提高应用程序的安全性。参数化的存储过程有助于保护应用程序不受SQL 注入攻击,此外还可以设定某些用户具有对指定存储过程的使用权限,保障数据库安全。
创建存储过程和 SPL 函数
1. 在 SPL 中创建存储过程的一般格式如下:
CREATE PROCEDURE <存储过程名> (<参数列表>) [SPECIFIC <重载函数名>]
{语句块}
END PROCEDURE;
其中,SPECIFIC 关键字表示可以指定 SPL 存储过程或函数一个简短的、独一无二的函数名称。这个名字在数据库中是唯一的。这一关键字也表明我们定义的存储过程和函数是可以重载的,即可定义多个具有相同名字的 SPL 函数,它们虽然名称相同,但是参数或类型各不相同。
语 句 块 即 一 组 SPL 或 SQL 语 句 , 隐 式 的 语 句 块 包 含 在 CREATE PROCEDURE/FUNCTION 和 END PROCEDURE/FUNCITON 之间,可使用 BEGIN 和 END来显式地指明内嵌在另一个语句块中的语句块。
2. 创建 SPL 函数的一般格式如下:
CREATE FUNCTION <函数名> (<参数列表>) RETURNING <返回值类型>[AS <返回值名>]
[SPECIFIC <重载函数名>]
{语句块}
END FUNCTION;
RETURNING 或 RETURNS 关键字用来定义返回值的返回类型,返回类型可以是除Serial/Serial8 和 Text/Byte 外的任意一种 SQL 的数据类型,在定义返回值类型时我们可以使用 AS 为返回值取一个名字。在过程体内必须至少有一个 return 语句。