SQLSERVER存储过程(一)
来源:互联网 发布:status monitor软件 编辑:程序博客网 时间:2024/05/18 00:48
一、什么是存储过程呢?
存储过程就是作为可执行对象存放在数据库中的一个或多个SQL命令。
通俗来讲:存储过程其实就是能完成一定操作的一组SQL语句。
二、用存储过程的目的
1.存储过程只在创造时进行编译,以后每次执行存储过程都不需再重新编译,而一般SQL语句每执行一次就编译一次,所以使用存储过程可提高数据库执行速度。
2.当对数据库进行复杂操作时,可将此复杂操作用存储过程封装起来与数据库提供的事务处理结合一起使用。
3.存储过程可以重复使用,可减少数据库开发人员的工作量。
4.安全性高,可设定只有某些用户才具有对指定存储过程的使用权
下面用例子来说明一下:
1.简单带参数例子
全局变量也称为外部变量,是在函数的外部定义的,它的作用域为从变量定义处开始,到本程序文件的末尾。
create proc stuProc2
@stuName varchar(100)
as
begin
select stuNo,stuName from dbo.Student where stuName=@stuName
end
go
stuProc2 ‘fsad’ //执行例子
得出结果:
2.带输出的例子
create proc stuProcOutPut
@stuName varchar(100), –声明全局变量
@type int output
as
begin
if exists (select * from dbo.Student where stuName=@stuName)
set @type=1
else
set @type=0
end
go
–declare的含义是定义一个存储过程中使用的变量,与AS之前括号中的变量不一样。
–括号之中的变量id和name是外部编程中使用的变量。其实有点像是函数内部变量和外部变量,可以这么理解。
declare @a int
exec stuProcOutPut ‘fsad’,@a output
select @a as UI
输出结果:
3.局部变量
局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。
局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型}
局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式}
局部变量的显示:select @变量名
例子1:
create proc JBBL
as
–声明局部变量
declare
@name varchar(100),
@sex varchar(100)
set @name=’fsad’
set @sex=’fsda’
begin
select * from Student where stuName=@name and stuSex=@sex
end
go
exec JBBL
结果:
例子2:把局部变量显示数据显示出来
create proc JBBL1
as
–声明局部变量
declare
@name varchar(100),
@sex varchar(100)
set @name=’fsad’
set @sex=’fsda’
begin
–设置变量的值然后输出
set @name=(select stuName from Student where stuName=@name);
select @name as NAME;
end
go
exec JBBL1
结果:
- SQLSERVER存储过程(一)
- sqlserver存储过程集锦(一)
- SQLServer 存储过程 带事务处理实例(一)
- SqlServer CLR存储过程使用一例
- SQLServer编写存储过程小工具(一)
- 网络工作室暑假后第二次培训资料(SQLServer存储过程和ADO.NET访问存储过程)整理(一)
- 存储过程(一)
- 存储过程(一)
- 存储过程(一)
- 存储过程(一)
- 存储过程(一)
- SQLServer 分页存储过程(1)
- java 调用通用存储过程(Sqlserver)
- sqlserver存储过程集锦(二)
- SqlServer存储过程(带参数)
- SQLSERVER存储过程基本语法(上)
- SQLSERVER存储过程基本语法(中)
- SQLSERVER存储过程基本语法(下)
- Maven项目管理工具初体验
- 深大云网络的PHP视频教程
- 12
- DeepID2——强大的人脸分类算法
- ASP.NET MVC分页问题解决
- SQLSERVER存储过程(一)
- Creating CocoaPods
- AndroidStudio 集成高德地图,无法实例化com.amap.api.maps.MapView。
- windows系统如何设置串口
- ES权威指南_01_get start_04 Distributed Document Store
- 三星公布Note7燃损原因未来创新的同时将更加注重安全检查
- 创业布局移动端App,应该先做Android还是iOS?
- Dynamic Library 动态库
- Android客户端和服务端如何使用Token和Session