SQL Server 2008存储过程调试的相关知识是本文我们主要要介绍的内容,接下来我们就来分别介绍一下SSMS中的调试以及在VS中的调试的设置,希望能够对您有所帮助。
1.在SQL Server 2008中调试存储过程
SQL Server 2008的SSMS是支持单步debug的,但是在调试之前必须配置权限。
如果 SQL Server Management Studio 与 SQL Server 数据库引擎实例在同一台计算机上运行,则对于运行 Transact-SQL 调试器没有配置要求。但是,当 SQL Server Management Studio 与数据库引擎实例在不同计算机上运行时,若要运行 Transact-SQL 调试器,则必须在两台计算机上使用“Windows 防火墙”控制面板应用程序来启用程序和端口例外。
在运行数据库引擎实例的计算机上,在“Windows 防火墙”中指定以下信息:
将TCP端口135添加到例外列表。
将程序sqlservr.exe添加到例外列表。默认情况下,sqlservr.exe 安装在 C:\Program Files\Microsoft SQL Server\MSSQL10.实例名称\MSSQL\Binn 下,其中,实例名称对于默认实例为 MSSQLSERVER,对于任何指定的实例则为相应实例的名称。
如果域策略要求通过 IPSec 进行网络通信,还必须将 UDP 端口 4500 和 UDP 端口 500 添加到例外列表。
在运行 SQL Server Management Studio 的计算机上,在“Windows 防火墙”中指定以下信息:
将TCP端口135添加到例外列表。
将程序ssms.exe (SQL Server Management Studio) 添加到例外列表。默认情况下,ssms.exe 安装在 C:\Program Files\Microsoft SQL Server\100\Tools\Binn\VSShell\Common7\IDE 下。
启动Transact-SQL 调试器的要求如下:
我们建议在测试服务器上调试 Transact-SQL 代码,而不要在生产服务器上调试,原因如下:
启动 Transact-SQL 调试器可将查询编辑器窗口置于调试模式。在查询编辑器窗口进入调试模式时,调试器会在第一个代码行处暂停。然后,您可以单步执行代码,在特定 Transact-SQL 语句上暂停执行,并使用调试器窗口来查看当前执行状态。可以通过在“查询”工具栏上单击“调试”按钮,或在“调试”菜单上单击“启动调试”来启动调试器。
查询编辑器窗口会保持在调试模式下,直到查询编辑器窗口中的最后一个语句完成或您停止调试模式。可以使用以下任何一种方法来停止调试模式和语句执行:
也可在“调试”菜单上单击“全部分离”,以停止调试模式,但允许剩余的 Transact-SQL 语句完成执行。
SQL Server Management Studio必须在作为sysadmin固定服务器角色成员的Windows帐户下运行。
数据库引擎查询编辑器窗口必须使用Windows身份验证来连接,或使用作为sysadmin固定服务器角色成员的SQL Server身份验证登录名来连接。
数据库引擎查询编辑器窗口必须连接到SQL Server 2008数据库引擎的实例。如果查询编辑器窗口连接到处于单用户模式下的实例,您将无法运行调试器。
调试是一项需要高特权的操作。因此只允许sysadmin固定服务器角色成员在SQL Server中进行调试。
当您调查多个Transact-SQL语句的运行时,调试会话通常会运行很长时间。会话获取的锁(如更新锁)可能会持有很长时间,直到终止会话或者提交或回滚事务。
在“调试”菜单中,单击“停止调试”。
在“调试”工具栏上,单击“停止调试”按钮。
在“查询”菜单上,单击“取消执行查询”。
在“查询”工具栏上,单击“取消执行查询”按钮。
2.在Visual Studio中调试存储过程(以VS2010为例)
打开服务器资源管理器,添加一个SQL Server 2008数据库连接,然后在存储过程节点上点右键,选择“单步执行存储过程”,即可进入单步调试状态,同上边过程,也要设置权限。这里就不再详细介绍了。
关于SQL Server 2008 存储过程调试的相关知识就介绍到这里了,希望本次的介绍能够对您有所收获!
【编辑推荐】