(数据库)-存储过程

来源:互联网 发布:游族网络股票 编辑:程序博客网 时间:2024/06/05 05:36

存储过程

存储过程(Stored Procedure)

  • 是一组为了完成特定功能的SQL语句集。经编译后存储在数据库中。
  • 是数据库中的一个重要对象,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
  • 是由 流控制 和 SQL语句书写的过程,这个过程经编译和优化后存储在数据库服务器中。
  • 可由应用程序通过一个调用来执行,而且允许用户声明变量。
  • 可以接收和输出参数、返回执行存储过程的状态值,也可以嵌套调用

功能

  • ① 变量说明
  • ② ANSI兼容的SQL命令(如Select,Update….)
  • ③ 一般流程控制命令(if…else…、while….)
  • ④ 内部函数

优点

  • 增强了SQL语言的功能和灵活性

    • 可以用流控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的 运算
  • 保证数据的安全性和完整性

    • 通过存储过程可以使相关的动作在一起发生,从而可以维护数据库的完整性
    • 通过存储过程可以使没有权限的用户在控制之下间接地存取数据库,从而保证数据的安全
  • 运行存储过程前,数据库已对其进行了语法和句法分析,并给出了优化执行方案

    • 已经编译好的过程可极大地改善SQL语句的性能。
      由于执行SQL语句的大部分工作已经完成,所以存储过程能以极快的速度执行
  • 可以降低网络的通信量

    • 客户端调用存储过程只需要传存储过程名和相关参数即可,与传输SQL语句相比自然数据量少了很多
  • 使体现企业规则的运算程序放入数据库服务器中

    • 集中控制
    • 当企业规则发生变化时在服务器中改变存储过程即可,无须修改任何应用程序

    • 企业规则的特点是要经常变化,如果把体现企业规则的运算程序放入应用程序中,则当企业规则发生变化时,就需要修改应用程序工作量非常之大(修改、发行和安装应用程序)。
      如果把体现企业规则的运算放入存储过程中,则当企业规则发生变化时,只要修改存储过程就可以了,应用程序无须任何变化

优缺点概括

  • 优点

    • 只需编译一次,在创造时进行编译,而一般SQL语句每执行一次就编译一次,可提高数据库执行速度。
    • 当对数据库进行复杂操作时(如对多个表进行Update,Insert,Query,Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用
    • 可以重复使用,可减少数据库开发人员的工作量
    • 安全性高,可设定只有某些用户才具有对指定存储过程的使用权
  • 缺点

    • 调试麻烦,但是用 PL/SQL Developer 调试很方便!弥补这个缺点
    • 移植问题,数据库端代码当然是与数据库相关的。但是如果是做工程型项目,基本不存在移植问题
    • 重新编译问题,因为后端代码是运行前编译的,如果带有引用关系的对象发生改变时,受影响的存储过程、包将需要重新编译(不过也可以设置成运行时刻自动编译)
    • 如果在一个程序系统中大量的使用存储过程,到程序交付使用的时候随着用户需求的增加会导致数据结构的变化,接着就是系统的相关问题了,最后如果用户想维护该系统可以说是很难很难、而且代价是空前的,维护起来更麻烦

分类

  • 系统存储过程:以sp_开头,用来进行系统的各项设定.取得信息.相关管理工作
  • 本地存储过程:用户创建的存储过程是由用户创建并完成某一特定功能的存储过程,事实上一般所说的存储过程就是指本地存储过程
  • 临时存储过程:分为两种存储过程:

    • 一是本地临时存储过程,以井字号(#)作为其名称的第一个字符,则该存储过程将成为一个存放在tempdb数据库中的本地临时存储过程,且只有创建它的用户才能执行它;
    • 二是全局临时存储过程,以两个井字号(##)号开始,则该存储过程将成为一个存储在tempdb数据库中的全局临时存储过程,全局临时存储过程一旦创建,以后连接到服务器的任意用户都可以执行它,而且不需要特定的权限
  • 远程存储过程:在SQL Server2005中,远程存储过程(Remote Stored Procedures)是位于远程服务器上的存储过程,通常可以使用分布式查询和EXECUTE命令执行一个远程存储过程

  • 扩展存储过程:扩展存储过程(Extended Stored Procedures)是用户可以使用外部程序语言编写的存储过程,而且扩展存储过程的名称通常以xp_开头

存储过程代码

创建格式:

create procedure sp_name@[参数名] [类型],@[参数名] [类型]asbegin.........end

上面可简写成

create proc sp_name@[参数名] [类型],@[参数名] [类型]asbegin.........end

调用过程格式:

exec sp_name [参数名]

删除存储过程:
不能在一个存储过程中删除另一个存储过程,只能调用另一个存储过程

drop procedure sp_name

其他常用命令

show procedure status显示数据库中所有存储的存储过程基本信息,包括所属数据库,存储过程名称,创建时间等

5“` python
show create procedure sp_name
显示某一个mysql存储过程的详细信息

``` pythonexec sp_helptext sp_name显示你这个sp_name这个对象创建文本

原创粉丝点击