技术开发 频道

SQL server数据库存储过程测试方法

  问题

  如何测试返回一个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"这种形式进行传递。

0
相关文章