- 15
- 0
- 约2.93千字
- 约 7页
- 2016-10-08 发布于贵州
- 举报
怎样在Sql srver中创建、执行和删除存储过程
怎样在Sql server中创建、执行和删除存储过程
首先,储存过程的分类:
1. 系统存储过程,存放在MASTER数据库中,以SP_前缀。
2. 用户自定义存储过程。
?
在SQL SERVER中创建储存过程语法:
Create proc[edure] procedure_name[;number]
[{@parameter data_type}
[varying][=default][output]
][,…n]
[with {recompile|encryption|encrypton,recomption}]
[for enplication]
As
Sql_statement[,…n]
参数:
整个语法中只有两个参数是必须的:procedure_name存储过程名称和sql_statement存储过程内容。
procedure_name:存储过程名称。
;number:对存储过程分组,“;数字”表示是一组存储过程,便于批量操作。
@parameter:参数名,命名必须用@开头;局部变量以@开头,全局变量以@@开头。
data_type:参数类型。
varying:指定作为输出参数的结果集。
Default:参数的默认值。
Output:表示为输出参数,返回值给execute/exe。
[with {recompile|encryption|encrypton,recomption}][for enplication]:这个我还不明白。。。
As:指定储存过程要执行的操作。
?
执行存储过程语法:
Exec[ute] 存储过程名 参数
?
实验一下,看看效果:
1.创建一组存储过程并且执行
create procedure procedure_a;1
as
select * from student
go
create procedure procedure_a;2
as
select * from student
go
执行创建效果截图:
图1创建一组存储过程
2.执行语句:
Execute procedure_a
效果截图:
图2执行存储过程效果截图
3.删除语句:
Drop procedure procedure_a
效果截图
图3删除一组储存过程效果截图
?
创建带输入参数的存储过程:输入参数是程序将参数值传递给存储过程。
创建一个带输入参数的存储过程,设置默认值,并且对输入参数的值进行判断。
Create procedure pro_1
@pro_1_a varchar(20)=null
As
If @pro_1_a is null
Print请输入需要查询的所属院系:
else
Select avg(成绩) from student where 所属院系=@pro_1_a
分别执行一下:
1.exec pro_1
效果截图:
图4执行不带输入参数的语句
2.exec pro_1 ‘计算机’
效果截图:
图5执行带输入参数的语句
?
创建带输出参数的存储过程:输出参数是存储过程将返回值传递给程序。
1.输出函数需要指定output作为标识
2.声明变量需要使用declare
3.给变量指定值需要使用select
来一个例子:如果一个数大于5,则计算他的阶乘。
Create procedure pro_2
/*声明输入输出参数*/
@in_x int,
@out_y int output
as
/*声明标量,并且赋值为1*/
Declare @x int,@y int
Select @x=1,@y=1
/*if语句判断输入值是否合法,使用while循环语句计算*/
If @in_x=5
Print请输入大于5的数:
Else
While @x=@in_x
Begin
Select @y=@y*@x
Select @x=@x+1
End
Select @out_y=@y
1.执行以上创建代码
图6创建带输入输出参数的存储过程截图
2.提供参数执行代码
Declare @out_sum int
Exec pro_2 6,@out_sum output
Select @out_sum as result
图7提供输入输出参数执行存储过程截图
?
创建多条语句的存储过程:一个存储过程中可以写入多条SQL语句,这些语句将被依次执行,可以实现多个功能。
?
删除存储过程delete及判断对象是否存在exists:
Delete procedure procedure_name
If exists(select子查询):如果exists的参数查询为非空,则exists结果为true,否则为假。
存储过程作为一个对象将被保存在数据库的sysobjects表中,可以使用语句判断这个对象是否存在:s
您可能关注的文档
- 循环流化床锅炉锅吊装方案.doc
- 循环流化床锅炉锅烘炉、煮炉及试运行方案.doc
- 循环流化床锅炉风存在问题及对策.doc
- 循证医学统计学英词汇对照.doc
- 微信5.0打造全环体验 移动互联新生活来了.doc
- 循证护理干预措施脊柱转移癌患者压疮和负性情绪的影响.doc
- 微信公众平台运营功案例集锦.docx
- 微信营销实战兵法天深度实操落地运营班-森涛培训.doc
- 微信个性签名大全伤感_经典搞_笑微_微信签名供大家分享.docx
- 微信营销实战兵法天深度实操落地运营班.doc
- 人教版九年级英语Unit 4曾害怕课件3a-4c.pdf
- 雅思口语考题回顾:朗阁海外考试研究中心2019年10月10日Part 1考题总结.pdf
- 2026届高三地理一轮复习课件小专题河流袭夺.pptx
- 【名师原创】复习专题5 三角函数 作者:合肥市第八中学 蒲荣飞名师工作室.docx
- 高中数学一轮复习 微专题2 抽象函数.docx
- 高中数学——复习专题4 空间向量与立体几何.docx
- 高中数学一轮复习 微专题3 空间几何体中的截面、轨迹问题.docx
- 高中数学一轮复习 微专题4 空间几何体的最值、范围问题.docx
- 导流洞施工质量通病防治手册.docx
- 江苏省徐州市第一中学、徐市第三中学等五校2026届高三上学期12月月考历史试题含答案.docx
最近下载
- 1消毒供应中心烫伤应急预案演练脚本.docx VIP
- 1消毒供应中心跌倒应急预案演练脚本.docx VIP
- 高中数学同步精品讲义:二次函数定(动)轴与定(动)区间六大题型汇总.pdf VIP
- 消毒供应中心跌倒应急预案脚本.doc VIP
- 学堂在线 雨课堂 学堂云 战场侦察监视技术与装备 章节测试答案.docx VIP
- 第五届新疆中小学生天文奥林匹克竞赛决赛试题答案-初中.docx.pdf VIP
- 学堂在线 雨课堂 学堂云 现代生活美学——花香茶之道 章节测试答案.docx VIP
- 软件工程专业培养方案.doc VIP
- 最新医疗废物管理条例.pptx
- 第五届新疆中小学生天文奥林匹克竞赛决赛试题答案-高中.docx.pdf VIP
原创力文档

文档评论(0)