什么是存储过程呢?
存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。
局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型}
局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式}
局部变量的显示:select @变量名
存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。
通俗来讲:存储过程其实就是能完成一定操作的一组SQL语句。
那为什么要用存储过程呢?
1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
2.当对数据库进行复杂操作时,可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
3.存储过程可以重复使用,可减少数据库开发人员的工作量。
4.安全性高,可设定只有某些用户才具有对指定存储过程的使用权
下面介绍一下存储过程的简单用法:
1、无参数存储过程
create proc StuProc
as --此处 as 不可以省略不写
begin --begin 和 end 是一对,不可以只写其中一个,但可以都不写
select * from UserInfo
end
go
exec StuProc 执行存储过程(在创建存储过程的时候,不写执行操作,在后台代码中以存储过程的方式读取数据仍可访问到)
drop proc StuProc 删除存储过程
2、有参数的存储过程
create proc Test1
@mobile varchar(100)
as
begin
select * from userinfo where Mobile=@mobile
end
go
exec Test1 '123456789'
创建存储过程的时候可以直接对变量赋值,比如上面的第二行,可以直接写成@mobile varchar(100)='12345678'
也可以将变量输出:
create proc Test2
@mobile varchar(100),
@IsRight int output --传出参数
as
if exists (select * from UserInfo where Mobile=@mobile)
set @IsRight =1
else
set @IsRight=0
go
declare @IsRight int
exec Test2 '17621733756' , @IsRight output
select @IsRight
以上是全局变量,下面来了解局部变量
局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型}
局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式}
局部变量的显示:select @变量名
create proc Test3
as
declare @sname varchar(100)
set @sname=(select mobile from UserInfo where mobile='13700000000')
select @sname
go
exec Test3
SQL Server中查看存储过程
转载:https://www.cnblogs.com/louby/p/6559564.html