前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >存储过程基础知识

存储过程基础知识

作者头像
全栈程序员站长
发布2021-12-24 08:18:53
4080
发布2021-12-24 08:18:53
举报
文章被收录于专栏:全栈程序员必看

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

http://hovertree.com/h/bjaf/b05uxijr.htm

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

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

存储过程基础知识
存储过程基础知识

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

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

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

代码语言:javascript
复制
   create proc StuProc
 
@sname varchar(100) 
 
as 
 
begin
 
select S#,Sname,Sage,Ssex from student where sname=@sname
 
end
 
go
 
— 何问起 hovertree.com 
 
exec StuProc ‘赵雷’ //执行语句  

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

代码语言:javascript
复制
   create proc StuProc
 
@sname varchar(100)=’赵雷’
 
as 
 
begin
 
select S#,Sname,Sage,Ssex from student where sname=@sname
 
end
 
go
 
— 何问起 hovertree.com 
exec StuProc  

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

代码语言:javascript
复制
   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
 
— 何问起 hovertree.com 
 
declare @IsRight int 
 
exec StuProc ‘赵雷’ , @IsRight output
 
select @IsRight  

以上是全局变量,下面来了解局部变量 局部变量也称为内部变量。局部变量是在函数内作定义说明的。其作用域仅限于函数内部,离开该函数后再使用这种变量是非法的。 局部变量的定义:必须先用Declare命令定以后才可以使用,declare{@变量名 数据类型} 局部变量的赋值方法:set{@变量名=表达式}或者select{@变量名=表达式} 局部变量的显示:select @变量名

代码语言:javascript
复制
   create proc StuProc
 
as 
 
declare @sname varchar(100)
 
set @sname=’赵雷’
 
select S#,Sname,Sage,Ssex from student where sname=@sname
 
go
 
— 何问起 hovertree.com 
 
exec StuProc  

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

代码语言:javascript
复制
   create proc StuProc
 
as 
 
declare @sname varchar(100)
 
set @sname=(select Sname from student where S#=01)
 
select @sname
 
go
 
— 何问起 hovertree.com 
 
exec StuProc  

推荐:http://www.cnblogs.com/roucheng/p/3541165.html

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档