永发信息网

怎样在Sql server中创建,执行和删除存储过程

答案:1  悬赏:60  手机版
解决时间 2021-01-15 04:53
怎样在Sql server中创建,执行和删除存储过程
最佳答案
存储过程是一类编译好的程序,在创建时进行编译,之后需要的时候值需要使用使用调用语句调用EXEC。

储存过程的分类:
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执行带输入参数的语句
哈哈,verygood,有进步啊。

创建带输出参数的存储过程:输出参数是存储过程将返回值传递给程序。
1.输出函数需要指定output作为标识
2.声明变量需要使用declare
3.给变量指定值需要使用select
来一个例子:如果一个数大于5,则计算他的阶乘。
Create procedure pro_2

@in_x int,
@out_y int output
as

Declare @x int,@y int
Select @x=1,@y=1

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表中,可以使用语句判断这个对象是否存在:select * from sysobjects where name=’procedure_name’

几个系统存储过程的使用:
Sp_name:重命名对象-- Sp_name object1,object2
Sp_depends:显示引用对象—sp_depends students
Sp_help:显示对象信息
Sp_helptext:显示对象的源代码
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
人家在问六十岁以后吃玛卡有坏处吗
今天我都用s挡开的车对我的新车有损害吗
甘精胰岛素与利拉鲁泰的区别
38+56/7x()二62的结果怎么算
六年前马刺夺冠,邓肯对詹姆斯说:“未来是你
胜字的日语发音是什么?
土壤缺硼的主要原因是什么
羊肉太腻和什么吃不腻
led背光条调光(灰度)是有几种啊?什么原理啊
陕西凤县,谁知道凤县到宝鸡的班车是什么颜色
砗磲与黄金可以佩在一起吗
X的三次方是关于x的三次式对吗
5个机器5分钟生产5个零件,100个机器100分钟
为什么我的oppofind5充满电后拔掉电源呼吸灯
谁知道这个福是什么字体吗
推荐资讯
由童话故事改编的歌曲
从康桥路沪南路到浦东大道德平路怎么坐公交车
我有一个年九十二国民华中5分钱现在能直多少
奥拉星自由之神背面
山西右玉包括几个乡镇
现在考驾驶证考完科二要多久才能考科三?谢谢
如何过Florisil柱?
地官符如何化解
三星的这个是什么图标
石材返绣,如何处理
白庙育苗幼儿园地址有知道的么?有点事想过去
诸暨国际商贸城的公交线路
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?