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

上传人:ni****g 文档编号:506298396 上传时间:2023-12-21 格式:DOC 页数:7 大小:262.50KB
返回 下载 相关 举报
怎样在Sql server中创建、执行和删除存储过程_第1页
第1页 / 共7页
怎样在Sql server中创建、执行和删除存储过程_第2页
第2页 / 共7页
怎样在Sql server中创建、执行和删除存储过程_第3页
第3页 / 共7页
怎样在Sql server中创建、执行和删除存储过程_第4页
第4页 / 共7页
怎样在Sql server中创建、执行和删除存储过程_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《怎样在Sql server中创建、执行和删除存储过程》由会员分享,可在线阅读,更多相关《怎样在Sql server中创建、执行和删除存储过程(7页珍藏版)》请在金锄头文库上搜索。

1、怎样在Sql server中创建、执行和删除存储过程首先,储存过程的分类:1. 系统存储过程,存放在MASTER数据库中,以SP_前缀。2. 用户自定义存储过程。在SQL SERVER中创建储存过程语法:Create procedure procedure_name;numberparameter data_typevarying=defaultoutput,nwith recompile|encryption|encrypton,recomptionfor enplicationAsSql_statement,n参数:整个语法中只有两个参数是必须的:procedure_name存储过程名称和

2、sql_statement存储过程内容。procedure_name:存储过程名称。;number:对存储过程分组,“;数字”表示是一组存储过程,便于批量操作。parameter:参数名,命名必须用开头;局部变量以开头,全局变量以开头。data_type:参数类型。varying:指定作为输出参数的结果集。Default:参数的默认值。Output:表示为输出参数,返回值给execute/exe。with recompile|encryption|encrypton,recomptionfor enplication:这个我还不明白。As:指定储存过程要执行的操作。执行存储过程语法:Execu

3、te 存储过程名 参数实验一下,看看效果:1.创建一组存储过程并且执行create procedure procedure_a;1asselect * from studentgocreate procedure procedure_a;2asselect * from studentgo执行创建效果截图:图1创建一组存储过程2.执行语句:Execute procedure_a效果截图:图2执行存储过程效果截图3.删除语句:Drop procedure procedure_a效果截图图3删除一组储存过程效果截图创建带输入参数的存储过程:输入参数是程序将参数值传递给存储过程。创建一个带输入参数的

4、存储过程,设置默认值,并且对输入参数的值进行判断。Create procedure pro_1pro_1_a varchar(20)=nullAsIf pro_1_a is nullPrint请输入需要查询的所属院系:elseSelect avg(成绩) from student where 所属院系=pro_1_a分别执行一下:1.exec pro_1效果截图:图4执行不带输入参数的语句2.exec pro_1 计算机效果截图:图5执行带输入参数的语句创建带输出参数的存储过程:输出参数是存储过程将返回值传递给程序。1.输出函数需要指定output作为标识2.声明变量需要使用declare3.

5、给变量指定值需要使用select来一个例子:如果一个数大于5,则计算他的阶乘。Create procedure pro_2/*声明输入输出参数*/in_x int,out_y int outputas/*声明标量,并且赋值为1*/Declare x int,y intSelect x=1,y=1/*if语句判断输入值是否合法,使用while循环语句计算*/If in_x=5Print请输入大于5的数:ElseWhile x=in_xBeginSelect y=y*xSelect x=x+1EndSelect out_y=y1.执行以上创建代码图6创建带输入输出参数的存储过程截图2.提供参数执行

6、代码Declare out_sum intExec pro_2 6,out_sum outputSelect out_sum as result图7提供输入输出参数执行存储过程截图创建多条语句的存储过程:一个存储过程中可以写入多条SQL语句,这些语句将被依次执行,可以实现多个功能。删除存储过程delete及判断对象是否存在exists:Delete procedure procedure_nameIf exists(select子查询):如果exists的参数查询为非空,则exists结果为true,否则为假。存储过程作为一个对象将被保存在数据库的sysobjects表中,可以使用语句判断这个

7、对象是否存在:select * from sysobjects where name=procedure_name几个系统存储过程的使用:Sp_name:重命名对象- Sp_name object1,object2Sp_depends:显示引用对象sp_depends studentsSp_help:显示对象信息Sp_helptext:显示对象的源代码存储过程必须是批查询中的第一条语句体验存储过程必须是批查询中的第一条语句的作用看代码如下:T-SQL-在查询分析器里面执行proc中的语句use pubsgocreate proc proc_P as select * from sysobjec

8、tsgodrop proc proc_P-可以正常执行-下面将这个在master库弄成存储过程,然后执行存储过程是否可以在pubs建立proc_P这个存储过程呢?-master库中创建存储-制表符 CHAR(9)-换行符 CHAR(10)-回车 CHAR(13)create proc proc_Masdeclare sql varchar(2000)set sql=use pubs+ CHAR(10) + CHAR(13) + go create proc proc_P as select * from sysobjects goexec(sql)go-执行存储过程-exec proc_M-错误信息-服务器: 消息 170,级别 15,状态 1,行 2第 2 行: go 附近有语法错误。服务器: 消息 111,级别 15,状态 1,行 3CREATE PROCEDURE 必须是批查询中的第一条语句。-CREATE PROCEDURE 必须是批查询中的第一条语句阻止了语句的执行。结论:初越的体验到了存储过程必须是批查询中的第一条语句语法结构的重要性,如若不然就可以跨越数据库建立存储过程,表等,这样一来的话。其他的库中的数据和信息就很容易被攻击和窃取。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号