SQL Server 7.0 入门(六)---建立存储过程体
2024-08-31 00:48:08
供稿:网友
建立存储过程体
存储过程逻辑驻留在存储过程体中。一个存储过程体中可以包含任意条transact sql语句。下面的transact sql语句不能在任何存储过程体中出现:
· create default
· create trigger
· create procedure
· create view
· create rule
1、 局部变量
局部变量保持存储过程中间值。当一个值在存储过程中需要多次,或者某个查询的结果需要在随后的查询中使用时,需要使用局部变量。在这些情形下,值被存储在局部变量中,并可用于将来的使用。本地变量的名称以“@”符号开头。变量的名称可以包含字符和数值。局部变量在使用前需要进行类型声明。对局部变量进行赋值需要使用select语句。select可以从一个表中检索出值并将其赋给某个变量,也可以给变量赋一个常量值。一个简单的select语句可以给多个局部变量赋值。
例如:
declare @var1 integer, @var2 varchar(20)
select @var1 = 32,
@var2 = ‘myage’
如果从select查询中没有返回任何数据,而select又要将数据的值赋予局部变量,则该局部变量的值将不会发生改变。
2、 条件词句
存储过程中提供的条件语句包括:
· if……else语句。
· while语句。
1) if……else语句。在该语句中包含三个部分:布尔运算表达式,if语句块和else语句块。语法如下:
if (boolen_expr)
{statements}
else
{statements}
在if或else语句块中可以有多条语句,这种情形下,需要语句begin和end来标志语句块。
2) while语句。while语句用于处理直到某个条件为true前重复执行的语句。语法如下:
while (boolen_expr)
begin
statement(s)
break
statement(s)
continue
end
begin和end语句标志循环体。break语句结束循环的执行(即走到end语句之后)。continue语句将控制处理过程回到循环的开始处(即begin语句的右边)。
注意:如果有两个或多个while循环被嵌套,则内部的break退出的是次外层的循环。内部循环结束之后的所有语句在内部循环执行之后才能继续执行。
3、 goto语句
在存储过程的执行中,语句是顺序执行的。goto语句则是用来打破这种语句执行的顺序,它立即跳到某条语句上执行,而这条语句往往不紧跟在前一语句之后。goto语句与一个标志(label)一起使用,该标志用来标识一条语句。
例如:
use pubs
go
declare @num int
select
if @num = 0
goto err
else
begin
print ‘authors found’
select * from authors
goto last
end
err: print ‘no authors found’
last: print ‘finish execution’
go
4、 return语句
return语句用于无条件的退出存储过程。return之后的任何语句都不再执行。return语句可以给调用语句返回一个值,但不能返回null值。sql server经常为存储过程返回一个状态值。如果成功地执行,则返回一个0,如果出现了错误,则返回一个为负数的错误码。
存储过程返回的错误码
值
说 明
值
说 明
0
过程执行成功
-8
发生了非致命的内部问题
-1
漏掉了对象
-9
达到了系统极限
-2
发生了数据类型错误
-10
发生了致命的内部不一致错误
-3
该处理被选择成了死锁的牺牲者
-11
发生了致命的内部不一致错误
-4
发生了权限错误
-12
表或索引被破坏
-5
发生了语法错误
-13
数据库被破坏
-6
发生了混杂的用户错误
-14
发生了硬件错误
-7
资源错误,如空间不够等
5、 使用游标(cursor)在需要一行一行处理时,游标十分有用。游标可以打开一个结果集合(按照指定的标准选择的行),并提供在结果集中一行一行处理的功能。基于游标的类型,可以对其进行回滚或者前进。在使用游标时需要5个步骤:注册会员,创建你的web开发资料库,