博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server之存储过程基础知识
阅读量:5032 次
发布时间:2019-06-12

本文共 2355 字,大约阅读时间需要 7 分钟。

http://www.cnblogs.com/jiajiayuan/archive/2011/06/15/2081201.html

什么是存储过程呢?

存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。 
通俗来讲:存储过程其实就是能完成一定操作的一组SQL语句。

那为什么要用存储过程呢?

1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
2.当对数据库进行复杂操作时,可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
3.存储过程可以重复使用,可减少数据库开发人员的工作量。
4.安全性高,可设定只有某些用户才具有对指定存储过程的使用权

那存储过程怎么用呢?

以下通过表Student 来了解存储过程,因为是要了解存储过程的简单用法,所以所有例子均很简单。

create table Student(--S# int identity(1,1),S# nvarchar(2),Sname varchar(10),Sage Datetime,Ssex char(2))insert into Student values('01','赵雷','1990-01-01','男');insert into Student values('02','钱电','1990-12-21','男');insert into Student values('03','孙风','1990-05-20','男');insert into Student values('04','李云','1990-08-06','男');insert into Student values('05','周梅','1991-12-01','女');insert into Student values('06','吴兰','1992-03-01','女');insert into Student values('07','郑竹','1989-07-01','女');insert into Student values('08','王菊','1990-01-20','女');drop table Student;select * from Student;

无参数存储过程:

选出Student表中的所有信息,

create proc StuProcas //此处 as 不可以省略不写begin //begin 和 end 是一对,不可以只写其中一个,但可以都不写select S#,Sname,Sage,Ssex from studentendgo

有参数存储过程:

全局变量
全局变量也称为外部变量,是在函数的外部定义的,它的作用域为从变量定义处开始,到本程序文件的末尾。
选出指定姓名的学生信息:

create proc StuProc@sname varchar(100) as beginselect S#,Sname,Sage,Ssex from student where sname=@snameendgoexec StuProc '赵雷' //执行语句

上面是在外部给变量赋值,也可以在内部直接给变量设置默认值

create proc StuProc@sname varchar(100)='赵雷'as beginselect S#,Sname,Sage,Ssex from student where sname=@snameendgoexec StuProc

也可以把变量的内容输出,使用output

create proc StuProc@sname varchar(100),@IsRight int output //传出参数as if exists (select S#,Sname,Sage,Ssex from student where sname=@sname)set @IsRight =1elseset @IsRight=0godeclare @IsRight int exec StuProc '赵雷' , @IsRight outputselect @IsRight

以上是全局变量,下面来了解局部变量

局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型}
局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式}
局部变量的显示:select @变量名

create proc StuProcas declare @sname varchar(100)set @sname='赵雷'select S#,Sname,Sage,Ssex from student where sname=@snamegoexec StuProc

那如果是要把局部变量的数据显示出来怎么办呢?

create proc StuProcas declare @sname varchar(100)set @sname=(select Sname from student where S#=01)select @snamegoexec StuProc

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,并在文章页面明显位置以超链接形式注明出处,否则保留追究法律责任的权利。

转载于:https://www.cnblogs.com/herizai/p/6590995.html

你可能感兴趣的文章
【eclipse jar包】在编写java代码时,为方便编程,常常会引用别人已经实现的方法,通常会封装成jar包,我们在编写时,只需引入到Eclipse中即可。...
查看>>
软件工程APP进度更新
查看>>
Python 使用正则替换 re.sub
查看>>
CTF中那些脑洞大开的编码和加密
查看>>
IdentityServer流程图与相关术语
查看>>
icon fonts入门
查看>>
【Django】如何按天 小时等查询统计?
查看>>
测试用例(一)
查看>>
邮件中的样式问题
查看>>
AJAX 状态值与状态码详解
查看>>
php面向对象编程(oop)基础知识示例解释
查看>>
树的子结构
查看>>
关于根据Build Platform或者OS 加载x86或者x64 dll的问题
查看>>
程序员高效开发的几个技巧
查看>>
js-权威指南学习笔记19.2
查看>>
hexo 搭建博客
查看>>
关键词 virtual
查看>>
建造者模式(屌丝专用)
查看>>
UVALive 4730 Kingdom +段树和支票托收
查看>>
[APIO2010]特别行动队
查看>>