概述
GBase 8a MPP Cluster 的存储过程仍在不断地完善中。本章中所描述的所有语法
都被有效地支持,其局限性和扩展要求将被记录备案。
存储过程
定义
存储过程是一组可以完成特定功能的 SQL 语句集,经编译后存储在数据库中。用
户在执行存储过程时,需要指定存储过程的名称并给出参数(如果存储过程里包
含参数)。
应用场景
在如下情况中,存储过程非常有用:
当多个客户端应用程序是由不同的语言编写,或者运行在不同的平台,但需
要执行同样的数据库操作时;
当安全非常重要时。例如,银行对所有常用的操作都使用存储过程。这提供
了一个一致的和安全的环境,并且存储过程可以保证每一个操作都正确的写
入日志。如此设置,应用程序和用户将不能直接访问数据表,只能执行特定
的存储过程;
存储过程可以提高性能,这是因为只需要在服务器和客户端之间传递更少的
信息。负面影响是增加了数据库服务器的负担,因为在服务器端执行更多的
任务而在客户端(应用程序)则只需执行较少的任务。这在一个或很少的数
据库服务器连接有大量客户端(比如 Web 服务器)的情况下则更明显;
存储过程允许用户在数据库服务器中使用函数库。这正是现代应用程序语言
具有的特性,例如,通过