【转】SQL Server之存储过程基础知识

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

那为何要用存储过程呢?
1.存储过程只在创造时进行编译,之后每次执行存储过程都不需再从新编译,而通常SQL语句每执行一次就编译一次,因此使用存储过程可提升数据库执行速度。
2.当对数据库进行复杂操做时,可将此复杂操做用存储过程封装起来与数据库提供的事务处理结合一块儿使用。
3.存储过程能够重复使用,可减小数据库开发人员的工做量。
4.安全性高,可设定只有某些用户才具备对指定存储过程的使用权数据库

那存储过程怎么用呢?
如下经过表Student 来了解存储过程,由于是要了解存储过程的简单用法,因此全部例子均很简单。
安全

无参数存储过程:
选出Student表中的全部信息,函数

create proc StuProc
as //此处 as 不能够省略不写
begin //begin 和 end 是一对,不能够只写其中一个,但能够都不写
select S#,Sname,Sage,Ssex from student
end
go

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

复制代码
create proc StuProc
@sname varchar(100) 
as 
begin
select S#,Sname,Sage,Ssex from student where sname=@sname
end
go

exec StuProc '赵雷' //执行语句
复制代码

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

复制代码
create proc StuProc
@sname varchar(100)='赵雷'
as 
begin
select S#,Sname,Sage,Ssex from student where sname=@sname
end
go

exec StuProc
复制代码

也能够把变量的内容输出,使用outputcode

复制代码
create proc StuProc
@sname varchar(100),
@IsRight int output //传出参数
as 
if exists (select S#,Sname,Sage,Ssex from student where sname=@sname)
set @IsRight =1
else
set @IsRight=0
go

declare @IsRight int 
exec StuProc '赵雷' , @IsRight output
select @IsRight
复制代码

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

复制代码
create proc StuProc
as 
declare @sname varchar(100)
set @sname='赵雷'
select S#,Sname,Sage,Ssex from student where sname=@sname
go

exec StuProc
复制代码

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

复制代码
create proc StuProc
as 
declare @sname varchar(100)
set @sname=(select Sname from student where S#=01)
select @sname
go

exec StuProc
复制代码
 

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

 

 
 转自:http://www.cnblogs.com/jiajiayuan/archive/2011/06/15/2081201.html
相关文章
相关标签/搜索