转自家园大哥博文http://www.cnblogs.com/jiajiayuan/archive/2011/06/15/2081201.html

什么是存储过程呢?
存储过程就是作为可执行对象存放在数据库中的一个或多个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#,Sname,Sage,Ssex from student where sname=@sname
end
go exec StuProc '赵雷' //执行语句

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


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

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


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 @变量名


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

最新文章

  1. 2 云计算系列之KVM的安装与使用
  2. css3 圆角
  3. JavaWeb学习总结-09 JDBC 学习和使用
  4. C#之XMAL与WPF
  5. UDP"打洞"原理
  6. 在Windows下编译FFmpeg详细说明
  7. acdream 1044
  8. This manual page is part of Xcode Tools version 5.0
  9. CSS 怀疑 Verify
  10. 设置Windows 8.1屏幕自己主动旋转代码, Auto-rotate function code
  11. 每天收获一点点------Hadoop Eclipse插件的使用
  12. Spark集群搭建中的问题
  13. 基于Metronic的Bootstrap开发框架--资产编码打印处理
  14. centos6.5安装ganglia-gmond
  15. C 语言实现基于 Linux 的端口扫描程序
  16. for in 循环 和for循环 for of循环
  17. C# 邮箱的使用
  18. 标准库 time
  19. 【PowerDesigner】【2】将工具栏显示出来
  20. PHP脚本不报错的两点原因

热门文章

  1. Android学习记录一——安装环境
  2. 通过github搭建个人博客
  3. jquery 回车事件实现代码
  4. 更改虚拟机UUID
  5. tensorflow的升级与版本管理
  6. SpringMVC系列(三):REST风格
  7. 新版本IntelliJ IDEA 构建maven,并用Maven创建一个web项目
  8. unity--------shader之standard 标准参数
  9. 嵌入式开发之uart---rs232 和rs485 通用自定义通信协议
  10. CI框架 -- 核心文件 之 Model.php