4

考虑这个存储过程。程序的实际内容无关紧要,我只是为了示例而使用它:

CREATE PROCEDURE [dbo].[temp]
      @value1 varchar(50),
      @value2 varchar(50),
      @value3 varchar(50)
as      
begin
    Select *
    From valuesTable (nolock)
          inner join valuesTable2 RL (nolock)
                on (ValuesTable.ID = RL.RuleId and RL.Type = 'Something')     
    where @value1 = ValuesTable.RuleVal02
    and cast(@value2 as float) > cast(ValuesTable.RuleVal03 as float) and cast(@value2 as float) < cast(ValuesTable.RuleVal04 as float)
    --and (@value3 = ValuesTable.RuleVal05)
    and (@value3 = ValuesTable.RuleVal05 or ValuesTable.RuleVal05 = -1)
end

现在想象这个(不是很复杂的功能)不起作用。我已经知道如何从 Visual Studio 和 SQL Server Management Studio 调试它,但是,这两种情况都缺乏:

这个函数的主要失败点是它执行的大查询。然后我想做的是获取这个查询,将它复制到一个新的查询窗口并开始执行它并通过修改它的各个部分来调试它。

调试该查询的基本方法是将其复制到新的查询窗口,从执行代码中获取参数,然后手动将所有参数替换@variables为其实际值。这行得通,但对我来说似乎是一项非常不必要的工作,理想情况下我想获取查询,因为它是在服务器上执行的 - 使用文字值而不是参数,例如:

where 'actualValue' = ValuesTable.RuleVal02
and cast(4.2 as float) > cast(ValuesTable.RuleVal03 as float) and cast(4.2 as float) < cast(ValuesTable.RuleVal04 as float)...

因为这听起来像是我只能通过分析器才能实现的东西,所以我启动了它。然后我将事件配置为捕获SP:StmtStarting事件,以查看从存储过程执行的语句。然而,令我惊讶的是,我在分析器中看到的语句仍然显示它们的参数,而不是实际的文字值。

有没有一种方法可以轻松复制在存储过程中执行的实际查询,并将参数替换为参数的文字值?探查器中是否有这样做的标志?还是有其他方法?

4

2 回答 2

2

试试这个简单的工作流程(需要 5 秒):

  1. 运行 SSMS。
  2. 在对象资源管理器窗口中找到您的存储过程。
  3. 右键单击它以显示上下文菜单并从中选择“执行存储过程...”。
  4. 在显示的表格中设置所有参数值。
  5. SSMS 在新的查询选项卡中为您生成脚本(请参阅此答案末尾的脚本)。
  6. 保存此脚本以供进一步使用。
  7. 运行 Debug -> Start Debugging this script 然后 Step Into EXEC 语句。
  8. 更改参数值并运行下一个调试。
DECLARE @return_value int

EXEC    @return_value = [dbo].[temp]
        @value1 = N'1',
        @value2 = N'2',
        @value3 = N'3'

SELECT  'Return Value' = @return_value
GO
于 2013-01-30T20:25:43.493 回答
1

您可以在变量中编写查询,使用占位符而不是实际值,在运行时替换占位符并使用 sp_executesql 执行它

显然,这只是出于调试目的而不是在生产中应该做的事情;)

这是一个例子:http ://sqlfiddle.com/#!3/c8c43/5

在那里,您的查询在变量内填充了实际内容

于 2012-11-14T16:52:53.057 回答