为代码减负之<二>存储过程(SQL)

在上篇博客中介绍到了触发器的使用,而且当中也提到了触发器是个特殊的存储过程,那么什么是存储过程呢?他们

两个又究竟有什么差别呢?

事实上最基本的差别就是,触发器是当满足条件时系统自己主动运行的,而存储过程是手动调用的。

简介

什么是存储过程?

定义:将经常使用的或非常复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来,用户通过指定存储过程的名字

并给出參数(假设该存储过程带有參数)来调用它。

说到这里,可能有人要问:这么说存储过程不就是一堆SQL语句而已吗?那么存储过程与一般的SQL语句有什么差别

呢?

存储过程有它独到的长处不单单仅仅是把一堆SQL语句堆积到一块:

1. 存储过程仅仅在创造时进行编译,以后每次运行存储过程都不需再又一次编译,而一般SQL语句每运行一次就编译

一次,所以使用存储过程可提高数据库运行速度。

2. 当对数据库进行复杂操作时(如对多个表进行Update,Insert,Query,Delete时),可将此复杂操作用存储过程封

装起来与数据库提供的事务处理结合一起使用。

3. 存储过程能够反复使用,可降低数据库开发者的工作量

4. 安全性高,可设定仅仅有某此用户才具有对指定存储过程的使用权

存储过程的种类:

1. 系统存储过程:以sp_开头,用来进行系统的各项设定.取得信息.相关管理工作,如sp_help就是取得指定对象的相关

信息

2. 扩展存储过程  以XP_开头,用来调用操作系统提供的功能

3. 用户自己定义的存储过程,这是我们所指的存储过程

怎样使用

这么好的一个东西,该怎么应用在系统中呢?

以机房收费系统的退卡功能为例。

  1. 第一步也是思考,思考这个功能涉及到了几条SQL语句(假设就一条就不必建立存储过程了),

把SQL语句都列出来:

delete Card_info  where CID = @CID                                                                  删除卡表中相应卡号的信息

delete Student_info   where SID = @SID                                                             依据卡号相应的学号删除学生表相应学号信息

insert into ReturnCard_info (CID,ReturnCash ,UID ,Rdate ,Rtime ) values(@CID ,@ReturnCash ,@UID ,@Rdate,@Rtime)                                               添加退卡信息到退卡记录表

  1. 建立存储过程  如图: 在对应数据库下打开可编程性,新建存储过程

  1. 加入对应存储过程的代码
--=============================================

--Author:                牛迁迁

--Create date:           2014年6月11日 

--Description:           退卡,删除Card_info,Line_info,Student_info,Recharge_info,同一时候加入ReturnCard_info

--=============================================

ALTER PROCEDURE [dbo].[PROC_ReturnCard]                             -- 命名规范   PROC_ + 名称 

--Add the parameters for the stored procedure here

@CID varchar(20),@ReturnCashvarchar(20),@UID varchar(20),           --  加入用到的參数

@Rdatevarchar(20),@Rtime varchar(20),@SID varchar(20)

AS

BEGIN

--SET NOCOUNT ON added to prevent extra result sets from

--interfering with SELECT statements.

SETNOCOUNT ON;

    -- Insert statements forprocedure here                         -- 加入涉及到的SQL语句

deleteCard_info  where CID = @CID

deleteStudent_info   where SID = @SID

insertinto ReturnCard_info (CID ,ReturnCash ,UID ,Rdate ,Rtime ) values(@CID,@ReturnCash ,@UID ,@Rdate ,@Rtime)

END
</span>
  1. 调用存储过程 (D层)
<span style="font-family:Microsoft YaHei;">
    Public Function ReturnCard(ENCardinfo As EN_Card_info, ENStudentinfo As EN_Student_info, ENLineinfo As EN_Line_info,ENReturnCardinfo As EN_ReturnCard_info) As Integer ImplementsIReturnCard.ReturnCard

        Dim strSql As String ="PROC_ReturnCard"            '这里的strSql不再存放单条SQL语句,而是存储过程

        '定义所需的參数

        Dim sqlParams As SqlParameter() = {NewSqlParameter("@CID", ENCardinfo.CID),

                                           NewSqlParameter("@SID", ENStudentinfo.SID),

                                           NewSqlParameter("@ReturnCash", ENReturnCardinfo.ReturnCash),

                                           NewSqlParameter("@UID", ENReturnCardinfo.UID),

                                           NewSqlParameter("@Rdate", ENReturnCardinfo.Rdate),

                                           NewSqlParameter("@Rtime", ENReturnCardinfo.Rtime)}

        '注意这里的CommandType不再是文本命令(CommandType.Text)而是CommandType.StoredProcedure

        ReturnclsSqlHelper.ExecAddDelUpdate(strSql, CommandType.StoredProcedure, sqlParams)

    End Function
</span>

假设没有存储过程的话,完毕这个过程,须要编写五个函数:删除卡信息的函数、删除学生信息的函数、删除

上级记录的函数、删除充值记录的函数、添加退卡记录的函数;然后再一个个调用,不仅代码繁多,并且关系乱;使

用存储过程仅仅须要编写一个函数就能够完毕五个函数的工作,使代码逻辑变得简单化。

存储过程和触发器,事实上就是把SQL语句封装到了数据库中,触发器能完毕的工作,存储过程一般也能完毕,可是选

择的时候要优先使用存储过程。

资料引用:http://www.knowsky.com/2951.html

时间: 2024-11-29 11:09:13

为代码减负之&lt;二&gt;存储过程(SQL)的相关文章

为代码减负之&lt;二&gt;存储过程(SQL)

在上篇博客中介绍到了触发器的使用,并且其中也提到了触发器是个特殊的存储过程,那么什么是存储过程呢?他们 两个又到底有什么区别呢? 其实最主要的区别就是,触发器是当满足条件时系统自动执行的,而存储过程是手动调用的. 简单介绍 什么是存储过程? 定义:将常用的或很复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来,用户通过指定存储过程的名字 并给出参数(如果该存储过程带有参数)来调用它. 讲到这里,可能有人要问:这么说存储过程不就是一堆SQL语句而已吗?那么存储过程与一般的SQL语句有什么区

为代码减负之&lt;三&gt;视图(SQL)

在设计数据库时为了减少数据冗余,一般都会按照三范式去设计,但有时我们在查询时需要通过一字段获取跟这 个字段相关联的好几个字段,但是他们又分布在不同的表中,这时候如果按照正常途径走的话需要同时查询好几张 表,不仅操作麻烦还容易出错.当然我们有捷径,把想要查询的字段都整合到一张虚拟表中,这就是视图的应用. 简单介绍     概念:视图是从若干基本表或其他视图构造出来的表,是一张虚拟的表,其内容由查询定义.同真实的表一样, 视图包含一系列带有名称的列和行数据.但是视图并不在数据库中以存储的数据值集形式

为代码减负之&lt;一&gt;触发器(SQL)

对触发器一词早有耳闻(最早是在耿大妈的数据库视频中),当初看完视频后,对理解不深刻的东西如:触发器,存储过程,事务,日志等等没有详细的去查阅,也没有具体的去尝试,应用.所以才导致了今天的博客(把以前丢下的补上).提到触发器一词,首先想到的是"触发器不能乱用","慎用触发器",不过我们可不能把这些提醒的话,当成了自己不去尝试的借口.学习要有无知者无畏的精神,管他呢,先试了再说. 简单介绍 概念:触发器是个特殊的存储过程(存储过程下篇博客中会讲到),它的执行不是由程序调

mysql学习笔记之十二(存储过程和函数)

存储过程和函数,一种数据库对象,用来实现将一组关于表操作的SQL语句代码当做一个整体来执行,也是与数据库对象表关联最紧密的数据库对象.在数据库系统中,当调用存储过程和函数时,则会执行这些对象中所设置的sql语句组从而实现相应的功能. 一.存储过程和函数的相关概念 针对表的一个完整操作往往不是单条sql语句就可以实现,而是需要一组sql语句来实现. 例: 为了购买商品的订单处理: (1)在生成订单之前,首先需要查看商品库存中是否有相应的商品 (2)如果库存中存在相应的商品,按着需要预定商品以便不将

SQL Server -为代码减负之触发器

触发器是一张表的增删改操作,引起或触发对另一张表的增删改操作,所以触发器便有3种类型,分别是deleted触发器,Update触发器,insert触发器 触发器又根据替换原来的增删改操作,还是在原来的增删改完成之后进行增删改操作,分为Instead of触发器和For或者After触发器(for和after属于一种触发器) 触发器的使用涉及到两张非常重要的表用来保存已经改变或者已经在第一章被操作的表上不存在的记录,分别是虚拟表Inserted和虚拟表Deleted 虚拟表Inserted 虚拟表

Android--新手必备的常用代码片段整理(二)

收集设备信息用于信息统计分析 是否有SD卡 动态隐藏软键盘 动态显示软键盘 动态显示或者是隐藏软键盘 主动回到Home后台运行 获取状态栏高度 获取状态栏高度标题栏ActionBar高度 获取MCCMNC代码 SIM卡运营商国家代码和运营商网络代码 返回移动网络运营商的名字 返回移动终端类型 判断手机连接的网络类型2G3G4G 判断当前手机的网络类型WIFI还是234G 收集设备信息,用于信息统计分析 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19

debian内核代码执行流程(二)

继续上一篇文章<debian内核代码执行流程(一)>未完成部分. acpi_bus_init调用acpi_initialize_objects,经过一系列复杂调用后输出下面信息: [ 0.147393] ACPI: SSDT 7f5e7cc0 0030F (v01 PmRef Cpu0Ist 00003000 INTL 20060912) [ 0.147566] ACPI: Dynamic OEM Table Load: [ 0.147569] ACPI: SSDT (null) 0030F

[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功)

原文:[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [顶]ORACLE PL/SQL编程详解之二: PL/SQL块结构和组成元素(为山九仞,岂一日之功) 继上四篇:ORACLE PL/SQL编程之八:把触发器说透                ORACLE PL/SQL编程之六:把过程与函数说透(穷追猛打,把根儿都拔起!)                [推荐]ORACLE PL/SQL编程之四:把游标说透(不怕做不到,只怕想不到) [推荐]

SQL Server 为代码减负之存储过程

    存储过程能够用来提高数据库的查询效率.由于它事先被编译过.被储存于内存中,每次执行前.不必被从新编译,所以效率非常高. 存储过程是一组sql增删改查的集合,假设程序中的一个功能涉及到对数据库的多次操作.那么就能够事先编译好存储过程.以提高程序执行效率!     简单查询: CREATE PROCEDURE sp_query_online_info AS SELECT *FROM T_OnLine_info GO 运行存储过程: EXEC sp_query_online_info 带參数的