sqlserver的存储过程
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlserver的存储过程相关的知识,希望对你有一定的参考价值。
继上一个数据库分页功能完成之后,这周开始进行一个sqlserver数据库的存储过程查询和运用。之前只了解过mysql数据库和oracle数据库,对于存储过程的了解只是在oracle数据库上面有所运用。加上对sqlserver数据库不太了解,所以一开始有点无从下手,看了一些资料。了解存储过程实际上就是将一些查询语句与数据库的事务处理相结合,方便我们在运用的时候可以直接调用存储过程里面的结果集,而不用每执行一个操作就写一个sql语句。下面一些资料来自于博客园园友 佳园
http://www.cnblogs.com/jiajiayuan
存储过程的基本知识:
as //此处 as 不可以省略不写
begin //begin 和 end 是一对,不可以只写其中一个,但可以都不写
select S#,Sname,Sage,Ssex from student
end
go
@sname varchar(100)
as
begin
select S#,Sname,Sage,Ssex from student where [email protected]
end
go
exec StuProc ‘赵雷‘ //执行语句
上面是在外部给变量赋值,也可以在内部直接给变量设置默认值
@sname varchar(100)=‘赵雷‘
as
begin
select S#,Sname,Sage,Ssex from student where [email protected]
end
go
exec StuProc
也可以把变量的内容输出,使用output
@sname varchar(100),
@IsRight int output //传出参数
as
if exists (select S#,Sname,Sage,Ssex from student where [email protected])
set @IsRight =1
else
set @IsRight=0
go
declare @IsRight int
exec StuProc ‘赵雷‘ , @IsRight output
select @IsRight
以上是全局变量,下面来了解局部变量
局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型}
局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式}
局部变量的显示:select @变量名
as
declare @sname varchar(100)
set @sname=‘赵雷‘
select S#,Sname,Sage,Ssex from student where [email protected]
go
exec StuProc
那如果是要把局部变量的数据显示出来怎么办呢?
as
declare @sname varchar(100)
set @sname=(select Sname from student where S#=01)
select @sname
go
exec StuProc
以上是关于sqlserver的存储过程的主要内容,如果未能解决你的问题,请参考以下文章
sqlserver中创建的存储过程,存储过程中定义的output参数在执行时提示错误???
sql存储过程参数可省略吗? 存储过程中参数都有默认值,调用时可不可以不传参数呢?