为代码减负之<二>存储过程(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步****** ...
随机推荐
- CentOS 安装apache 及所需的 apr,apr-util,pcre
安装apache前确定已安装 apr,apr-util,pcre 一.安装apr [root@xt test]# tar -zxf apr-1.4.5.tar.gz [root@xt test]# c ...
- bootstarp modal自己主动调整宽度的JS代码
$('#ajaxPage').modal('show').css({ width: 'auto', 'margin-left': function () { return -($(this).widt ...
- hdu 4944 FSF’s game(数论)
题目链接:hdu 4944 FSF's game 题目大意:给定N,能够用不大于N的长a和宽b.组成N∗(N−1)2种不同的矩形,对于每一个矩形a∗b要计算它的值,K为矩形a,b能够拆分成若干个K∗K ...
- Xamarin.Android 入门实例(3)之呼叫电话号码
1.Main.axml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns: ...
- 【iOS】文件上传小记
iOS由该系统提供API可以实现可以实现文件的上传和下载,有两种方法来. NSURLConnection与NSURLSession. 当中NSURLConnection是使用非常久的的一种方式.NSU ...
- Java SE学习之数组——匿名数组和不规则数组
本文是学习网络上的文章时的总结以及自己的一点实践.感谢大家无私的分享. 近期偶然遇到了数组的问题,学习了匿名数组和不规则数组. 匿名数组适用于仅仅使用一次的情况:不规则数组适用是每行数据总数不确定的情 ...
- Nagios显示器mysql定从库: libmysqlclient.so.18: cannot open shared object file: No such
做mysql的slave时间监控,必须check_mysql文字,check当误差: error while loading shared libraries: libmysqlclient.so.1 ...
- Apple Watch 1.0 开发介绍 2.1 WatchKit Apps UI要点
实现app的开始是定义storyboard场景.每个场景定义了app的一部分界面.可以为不同的尺寸自定义场景. 组装storyboard界面 WatchKit app和iOS app的布局模式不同.组 ...
- Android - 用Fragments实现动态UI - 和其他Fragments通信
为了重用Fragment UI组件,应该把每个都设计为它自有的模块组件并且有自己的布局和行为.一旦定义了这些可重用的Fragment,你可以把它们和一个activity关联然后和程序的逻辑一起实现上层 ...
- Windows 8实例教程系列 - 布局控制
原文:Windows 8实例教程系列 - 布局控制 与传统应用类似,Windows store应用允许开发人员通过布局控件管理应用UI. 本篇将讨论Windows8布局设计控制. Windows 8布 ...