为代码减负之<二>存储过程(SQL)
在上篇博客中介绍到了触发器的使用,而且当中也提到了触发器是个特殊的存储过程,那么什么是存储过程呢?他们
两个又究竟有什么差别呢?
事实上最基本的差别就是,触发器是当满足条件时系统自己主动运行的,而存储过程是手动调用的。
简介
什么是存储过程?
定义:将经常使用的或非常复杂的工作,预先用SQL语句写好并用一个指定的名称存储起来,用户通过指定存储过程的名字
并给出參数(假设该存储过程带有參数)来调用它。
说到这里,可能有人要问:这么说存储过程不就是一堆SQL语句而已吗?那么存储过程与一般的SQL语句有什么差别
呢?
存储过程有它独到的长处不单单仅仅是把一堆SQL语句堆积到一块:
1. 存储过程仅仅在创造时进行编译,以后每次运行存储过程都不需再又一次编译,而一般SQL语句每运行一次就编译
一次,所以使用存储过程可提高数据库运行速度。
2. 当对数据库进行复杂操作时(如对多个表进行Update,Insert,Query,Delete时),可将此复杂操作用存储过程封
装起来与数据库提供的事务处理结合一起使用。
3. 存储过程能够反复使用,可降低数据库开发者的工作量
4. 安全性高,可设定仅仅有某此用户才具有对指定存储过程的使用权
存储过程的种类:
1. 系统存储过程:以sp_开头,用来进行系统的各项设定.取得信息.相关管理工作,如sp_help就是取得指定对象的相关
信息
2. 扩展存储过程 以XP_开头,用来调用操作系统提供的功能
3. 用户自己定义的存储过程,这是我们所指的存储过程
怎样使用
这么好的一个东西,该怎么应用在系统中呢?
以机房收费系统的退卡功能为例。
第一步也是思考,思考这个功能涉及到了几条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) 添加退卡信息到退卡记录表
建立存储过程 如图: 在对应数据库下打开可编程性,新建存储过程
加入对应存储过程的代码
--=============================================
--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>
调用存储过程 (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语句封装到了数据库中,触发器能完毕的工作,存储过程一般也能完毕,可是选
择的时候要优先使用存储过程。
为代码减负之<二>存储过程(SQL)的更多相关文章
- 为代码减负之<一>触发器(SQL)
对触发器一词早有耳闻(最早是在耿大妈的数据库视频中),当初看完视频后,对理解不深刻的东西如:触发器,存储过程,事务,日志等等没有具体的去查阅,也没有具体的去尝试,应用.所以才导致了今天的博客(把曾经丢 ...
- Linux协议栈代码阅读笔记(二)网络接口的配置
Linux协议栈代码阅读笔记(二)网络接口的配置 (基于linux-2.6.11) (一)用户态通过C库函数ioctl进行网络接口的配置 例如,知名的ifconfig程序,就是通过C库函数sys_io ...
- 存储过程系列之存储过程sql数据库调用和程序代码调用
1.存储过程,无参数的存储过程 创建无参数存储存储过程 Create Procedure DCEMREMR_TEMPLATEAs SELECT TOP 10 [FILENAME],[FILETITLE ...
- SonarQube4.4+Jenkins进行代码检查实例之二
SonarQube4.4+Jenkins进行代码检查实例之二 SonarQube4.4+Jenkins进行代码检查实例之二
- [置顶] Linux协议栈代码阅读笔记(二)网络接口的配置
Linux协议栈代码阅读笔记(二)网络接口的配置 (基于linux-2.6.11) (一)用户态通过C库函数ioctl进行网络接口的配置 例如,知名的ifconfig程序,就是通过C库函数sys_io ...
- 数据库存储过程 — Sql Server
Mysql.Oracle等主流关系型数据库基本都支持存储过程,这里使用Sql Server为例进行说明. 存储过程的概念: Sql Server存储过程 SQL Server 中的存储过程是由一个或多 ...
- [顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功)
原文:[顶]ORACLE PL/SQL编程详解之二:PL/SQL块结构和组成元素(为山九仞,岂一日之功) [顶]ORACLE PL/SQL编程详解之二: PL/SQL块结构和组成元素(为山九仞,岂一日 ...
- JPA hibernate spring repository pgsql java 工程(二):sql文件导入数据,测试数据
使用jpa保存查询数据都很方便,除了在代码中加入数据外,可以使用sql进行导入.目前我只会一种方法,把数据集中在一个sql文件中. 而且数据在导入中常常具有先后关系,需要用串行的方式导入. 第一步:配 ...
- 一次性删除数据库所有表和所有存储过程 SQL语句
一次性删除数据库所有表和所有存储过程 SQL语句 今天转移数据库数据,需要把数据库原来的表和存储过程清空.删除所有的表:如果由于外键约束删除table失败,则先删除所有约束: --/第1步****** ...
随机推荐
- 重新想象 Windows 8 Store Apps (27) - 选取器: 联系人选取窗口, 自定义联系人选取窗口
原文:重新想象 Windows 8 Store Apps (27) - 选取器: 联系人选取窗口, 自定义联系人选取窗口 [源码下载] 重新想象 Windows 8 Store Apps (27) - ...
- NTP方式保证以时间戳同步可靠性
数据库同步的方式有设置标志位同步方式.以时间戳同步的方式,对于一对一的同步这两种方式都满足,可是对于一对多的同步,则仅仅能选择时间戳的同步方式了.可是已时间戳同步的方式的一个问题是怎样可靠的保证数据能 ...
- js右侧悬浮框
示例:屏幕右侧悬浮框 原理:oDiv.style.top = document.documentElement.clientHeight - oDiv.offsetHeight + scrollTop ...
- 设计模式 - Abstract Factory模式(abstract factory pattern) 详细说明
Abstract Factory模式(abstract factory pattern) 详细说明 本文地址: http://blog.csdn.net/caroline_wendy/article/ ...
- .net Quartz 服务 作业调度
.net项目中使用Quartz (1)在web.config中进行相关配置 <configSections> <section name="quartz" t ...
- 引用第三方框架 不支持ARC
我们会常常遇到一个问题就是引用第三方框架之后发现不支持内存的自己主动处理(ARC) 我们须要这样来操作: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdT ...
- 如何区分MNO和MVNO
MVNO(Mobile Virtaul Network Operator)虚拟网络运营商,没有自己的物理网络,租用MNO(Mobile Network Operator)网络提供的网络服务. 我们知道 ...
- UVA 11402 - Ahoy, Pirates!(段树)
UVA 11402 - Ahoy, Pirates! 题目链接 题意:总的来说意思就是给一个01串,然后有3种操作 1.把一个区间变成1 2.把一个区间变成0 3.把一个区间翻转(0变1,1变0) 思 ...
- jqm视频播放器,html5视频播放器,html5音乐播放器,html5媒体播放器,video开展demo,html5视频播放演示示例,html5移动视频播放器
最近看到很多有用的论坛html5视频播放的发展,音乐播放功能,大多数都在寻找答案.所以,我在这里做一个demo.对于大家互相学习.html5开发越来越流行,至于这也是一个不可缺少的一部分的视频. 如何 ...
- ZOJ3819 ACM-ICPC 2014 亚洲区域赛的比赛现场牡丹江司A称号 Average Score 注册标题
Average Score Time Limit: 2 Seconds Memory Limit: 131072 KB Bob is a freshman in Marjar Univers ...