51Testing软件测试论坛

标题: 存储过程测试 [打印本页]

作者: 乐哈哈yoyo    时间: 2017-6-15 09:58
标题: 存储过程测试
线上项目运行过程中,通常会有些bug,是直接修改数据库的存储过程就可以解决,类似这种情况,实际工作中会在真实环境执行存储过程之前,进行存储过程的测试,用到的方法如下:  
环境VS2013+SQL Server2012

数据库中存在存储过程(简单例子):  
-===========================================================================    --- Author:     shilinjie    -- ALTER date:  20170313    -- Descaption:  该存储过程用于通过id获取详情    -- ===========================================================================    ALTER proc [dbo].[getdetailbyid]        @ID int    AS    BEGIN        select * from tb_A where pid=@ID    END    --EXEC [getdetailbyid] '1'测试步骤打开VS2013,打开SQL Server对象资源管理器,如下图:

   



添加SQL Server:

  



填写连接数据库的用户名密码:

  



找到需要测试的存储过程,右键选择调试:

  



此时会弹出输入参数,本例中的存储过程只有一个参数id:

  



之后会进入调试状态,F11进行单步调试即可,鼠标指向参数,查看传入参数的值:

  



执行之后,会显示结果和返回值:

  



这只是个简单例子,测试过程中需要针对每个传入参数进行测试,如果存储过程中有分支,每个分支也都需要测试。  
可能遇到的问题问题:在启动sql server中,启动调试时报错:无法启动 transact-sql调试器  



  
解决方法:
将 Windows 登录帐户添加为 sysadmin,在sql server中执行:
  1. <span class="n">exec</span> <span class="n">sp_addsrvrolemember</span> <span class="err">'</span><span class="n">PC</span><span class="o">-</span><span class="n">name</span><span class="err">\</span><span class="n">Administrator</span><span class="err">'</span><span class="o">,</span> <span class="err">'</span><span class="n">sysadmin</span><span class="err">'</span>
复制代码



作者: 草帽路飞UU    时间: 2017-6-15 10:24
学习
作者: 乐哈哈yoyo    时间: 2017-6-15 10:25
草帽路飞UU 发表于 2017-6-15 10:24
学习






欢迎光临 51Testing软件测试论坛 (http://bbs.51testing.com/) Powered by Discuz! X3.2