GBASE 8s存储过程和函数简介

存储过程(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 语句。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

八珍豆腐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值