美文网首页
【工作笔记】存储过程

【工作笔记】存储过程

作者: 高桥my | 来源:发表于2020-02-15 18:37 被阅读0次
王一博

一、定义

存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,它存储在数据库中,一次编译后永久有效,用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象。

二、基本语法

1、创建存储过程

create procedure sp_name

@[参数名] [类型],@[参数名] [类型]

as

begin

.........

end

以上格式还可以简写成:

create proc sp_name

@[参数名] [类型],@[参数名] [类型]

as

begin

.........

end

/*注:"sp_name"为需要创建的存储过程的名字,该名字不可以以阿拉伯数字开头*/


2、调用存储过程

存储过程可以在三种环境下被调用:

command命令下,基本语法为:exec sp_name [参数名];

SQL环境下,基本语法为:call sp_name [参数名];

PL/SQL环境下,基本语法为:begin sp_name [参数名] end;

折叠删除存储过程

(1)基本语法:

drop procedure sp_name

(2)注意事项

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


3、其他常用命令

(1)show procedure status

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

(2)show create procedure sp_name

显示某一个mysql存储过程的详细信息

(3)exec sp_helptext sp_name

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

三、触发器 

触发器是一种特殊类型的存储过程,它不同于我们前面介绍过的存储过程。触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程名字而被直接调用。当对某一表进行诸如Update、 Insert、 Delete 这些操作时,SQL Server 就会自动执行触发器所定义的SQL 语句,从而确保对数据的处理必须符合由这些SQL 语句所定义的规则。

四、优缺点

1.优点

(1)重复使用。存储过程可以重复使用,从而可以减少数据库开发人员的工作量。

(2)减少网络流量。存储过程位于服务器上,调用的时候只需要传递存储过程的名称以及参数就可以了,因此降低了网络传输的数据量。

(3)安全性。参数化的存储过程可以防止SQL注入式攻击,而且可以将Grant、Deny以及Revoke权限应用于存储过程。

简单讲:

(1)存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。

(2)当对数据库进行复杂操作时(如对多个表进行Update,Insert,Query,Delete时),可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。

(3)存储过程可以重复使用,可减少数据库开发人员的工作量

(4)安全性高,可设定只有某些用户才具有对指定存储过程的使用权

有一点需要注意的是,一些网上盛传的所谓的存储过程要比sql语句执行更快的说法,实际上是个误解,并没有根据,包括微软内部的人也不认可这一点,所以不能作为正式的优点,希望大家能够认识到这一点。

2.缺点

(1)调试麻烦,但是用 PL/SQL Developer 调试很方便!弥补这个缺点。

(2)移植问题,数据库端代码当然是与数据库相关的。但是如果是做工程型项目,基本不存在移植问题。

(3)重新编译问题,因为后端代码是运行前编译的,如果带有引用关系的对象发生改变时,受影响的存储过程、包将需要重新编译(不过也可以设置成运行时刻自动编译)。

(4)如果在一个程序系统中大量的使用存储过程,到程序交付使用的时候随着用户需求的增加会导致数据结构的变化,接着就是系统的相关问题了,最后如果用户想维护该系统可以说是很难很难、而且代价是空前的,维护起来更麻烦。

五、实例

资料参考:

1.存储过程_360百科 https://baike.so.com/doc/2045557-2164405.html

2.oracle中的存储过程例子 - lingfeng95 - 博客园 https://www.cnblogs.com/zhao123/p/3911537.html

相关文章

  • 【工作笔记】存储过程

    一、定义 存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集,...

  • 【工作笔记】Oracle存储过程实战

    本篇围绕几种模式:无参存储过程、带参存储过程、带参数存储过程含赋值方式、存储过程中游标定义使用、异常使用分别举例使...

  • 存储过程入门笔记

    9102年1月 8102年12月

  • Oracle 存储过程学习笔记

    1、存储过程简单实例 2.游标实现方式 显式游标实现方式(可多值) 隐式游标(可以实现查询多值) 带有参数的游标(...

  • Mysql存储过程

    阅读目录:MySQL存储过程_创建-调用-参数 存储过程:SQL中的“脚本” 创建存储过程 调用存储过程 存储过程...

  • MySQL批量添加数据

    创建存储过程 执行存储过程 删除存储过程

  • 像极客一样写作

    像极客一样写作 回顾一下我做笔记过程: 一开始使用的是myBase软件,在分类存储管理上做得很好,作为工作笔记使用...

  • 17 存储过程

    过程: 函数: 过程是没有返回值的函数 存储过程: 存储过程语法 存储过程1--创建简单的存储过程 存储过程2--...

  • 存储过程

    详见存储过程详解 创建存储过程 使用存储过程 存储过程简介 什么是存储过程:存储过程可以说是一个记录集吧,它是由一...

  • 存储过程与函数

    存储过程与函数存储过程的定义存储过程的创建存储过程的操作自定义函数 存储过程与函数 存储过程的定义 运行效率高 降...

网友评论

      本文标题:【工作笔记】存储过程

      本文链接:https://www.haomeiwen.com/subject/svuyfhtx.html