打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
SQL存储过程测试(7)——当待测存储过程返回out参数时 如何判断测试结果是否通过

问题

 

      如何测试返回一个out参数的存储过程。

 

设计

 

      声明一个合适类型的变量,用于接受out参数,然后使用out参数调用待测存储过程。

 

方案

 

      例如,设想包含待测存储的数据库有一个数据库表,这个表定义如下:

 

create table tb1Employees

(

    empID char(3) primary key,

    empLast varchar(35) not null,

    empDOH datatime not null

)

 

      设想待测存储过程有一个out参数,这个参数用于保存返回结果,其定义如下:

 

create procedure usp_GetLast

    @empID char(3),

    @empLast varchar(35) out

as

    select @empLast = empLast from tb1Employees where empID = @empID

    return @@rowcount

 

那么用于测试这个存储过程的T-SQL代码可以是:

 

declare @input char(3)

declare @empLast varchar(35)

declare @retval int

 

declare @expectedLast varchar(35)

declare @expectedRet int

 

set @input = 'e22'

set @expectedLast = 'Baker'

set @expectedRet = 1

 

exec @retval = dbEmployees.dbo.usp_GetLast @input,@empLast out

if(@retval = @expectedRet and @empLast = @expectedLast)

    print 'Pass'

else

    print 'FAIL'

 

      存储过程usp_GetLast()接受一个雇员ID作为输入参数。这个存储过程取回雇员ID与输入ID相匹配的行并且把该雇员的姓氏存入一个out参数。该存储过程返回由SELECT语句所返回的行数。可以让AUT使用这个返回值作为一种错误的检查机制:如果返回值为0,就意味着没有找到与之匹配的雇员,但是如果返回值比1大,则说明有多于一个雇员拥有相同的ID(大多数情况下很可能出现了什么错误)。

 

注解

 

      SQL存储过程有一个常用的设计模式,即存储过程可以通过out参数返回一个或多个值。当存储过程要返回的值不是Int类型的时候,这种模式是必须的,因为return关键字只接受Int类型的变量。当存储过程必须要返回多个值的时候,这种模式也是必需的。

 

      调用带out参数的存储过程就跟调用只有输入参数的存储过程一样,只不过需要在接受输出变量的参数后面要加上SQL关键字out。上述方案是根据参数的位置进行调用的。也可以通过参数名称进行调用。但是,这种调用可能有些混乱,因为一旦使用了"@name = value"这种形式,后面的参数也必须以"@name = value"这种形式进行传递。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
SQL动态语句用法
SQL Server存储过程编程经验技巧
SQL SERVER数据库中存储过程使用循环语句
在sql server 中执行带参数的存储过程及计算运行时间
pgsql存储过程介绍
Java如何实现对存储过程的调用
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服