SQLServer之存储过程

SQLServer之存储过程,第1张

概述什么是存储过程呢? 存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。  通俗来讲:存储过程其实就是能完成一定 *** 作的一组SQL语句。 那为什么要用存储过程呢? 1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。 2.当对数据库进行复杂 *** 作时,可将此复杂 *** 作用存储过程封装起来与数据库提供的事

什么是存储过程呢?

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

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

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

无参数存储过程:
选出Student表中的所有信息,

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

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

create proc StuProc
@sname varchar(
100
as  
begin
select S#,Ssex from student 
where  sname = @sname
end
go

exec StuProc 
' 赵雷 //执行语句

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

100 ) = '
where  sname = @sname
end
go

exec StuProc

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

100 ),
@IsRight 
int  output //传出参数
as  
if  exists (select S#,255); Font-family: 'CourIEr new' !important;">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 @变量名

create proc StuProc
as  
declare @sname varchar(
100 )
set  @sname = '
select S#,Ssex from student 
where  sname = @sname
go

exec StuProc

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

create proc StuProc
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 总结

以上是内存溢出为你收集整理的SQLServer之存储过程全部内容,希望文章能够帮你解决SQLServer之存储过程所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1167681.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)