图6:ExistingSprocs.aspx页面最开始显示的是 饮料类的产品
图7:执行到存储过程设置的断点
在如图7所示的 Watch 窗口,参数@CategoryID的值为1,这是由于ExistingSprocs.aspx页面最开始显示的是饮料类产品的信息,而饮料类的CategoryID 值为1.在下拉列表里选择一个不同的值。这将导致页面回传并重新执行Products_SelectByCategoryID存储过程。再次遇到断点时,@CategoryID 参数的值就是你在下拉列表框里选择的CategoryID值.
图8:在下拉列表里选择一个不同的类
图9:参数@CategoryID反映的是在Web页面选择的类
注意:如果你登录ExistingSprocs.aspx 页面时,没有碰到在Products_SelectByCategoryID存储过程里设置的断点,一定要确保ASP.NET应用程序的“属性页”的 Debuggers区域的SQL Server项被选中;关闭连接池;激活数据库的Application Debugging项.如果仍然还有问题的话,重新启动Visual Studio并再试一次.
调试T-SQL 数据库对象的远程实例
在本地电脑上通过Visual Studio调试是比较直观容易的,但如果SQL Server和Visual Studio没有装在同一台机器上的话,我们需要做一些设置以使各方面工作正常,为此我们要做2方面的工作:
.确保以系统管理员的角色(sysadmin role)通过ADO.NET连接到数据库
.确保开发环境上Visual Studio使用的Windows user帐户是一个有效的属于系统管理员的角色(sysadmin role)的SQL Server登录帐户.
第一项相对比较简单.首先确定从ASP.NET应用程序连接到数据库的用户帐户,接下来通过SQL Server Management Studio,将该帐户添加到sysadmin角色.
第二项,你用来调试程序的Windows user帐户必须是连接到远程数据库的一个有效帐户,问题就在于你在本地工作站登录的Windows帐户不一定就是登录SQL Server的有效帐户.与其将你具体的登录帐户添加给SQL Server,一个更好的选择是将一些Windows user帐户分配为SQL Server调试帐户(SQL Server debugging account).然后,要调试一个远程SQL Server实例的数据库对象的话,你可以使用这些Windows登录帐户的认证(credentials)来运行Visual Studio.
用一个例子来进行阐述。假设有个Windows帐户,名为SQLDebug.该帐户应该添加到远程SQL Server实例,以系统管理员角色进行合法登录.然后要从Visual Studio来调试远程SQL Server实例的话,我们应该以SQLDebug帐户来运行Visual Studio.于是我们可以这样来操作:退出我们的工作站,以SQLDebug帐户再次登录,然后运行Visual Studio.不过还有一个更简单点的方法,不用退出工作站,通过使用runas.exe来以SQLDebug的名义运行Visual Studio.这个runas.exe允许一个应用程序假借另一个帐户的名义来执行.要以SQLDebug的名义来运行Visual Studio的话,你可以在命令行键入如下的statement:
runas.exe /user:SQLDebug "%PROGRAMFILES%/Microsoft Visual Studio 8/Common7/IDE/devenv.exe"
关于该过程的更详细介绍请参阅文章《How To: Set SQL Server Permissions for Debugging》((VS.80).aspx)
注意:如果你的开发机为Windows XP Service Pack 2版本的话,你需要对Internet连接防火墙进行配置以允许远程调试。文章《The How To: Enable SQL Server 2005 Debugging》((VS.80).aspx)对此进行了描述,该过程包括2步:(a)在Visual Studio所在的主机,你必须向Exceptions list添加Devenv.exe,并打开TCP 135端口;(b)在远程(SQL)机器,你必须打开TCP 135端口,且向Exceptions list添加Dsqlservr.exe.如果你的域策略(domain policy)需要通过IPSec来进行网络通信(network communication)的话,你必须打开UDP 4500 和 UDP 500端口。
结语:
除了支持对.NET程序代码进行调试外,Visual Studio也提供了对SQL Server 2005进行调试的多种选择.在本文,我们考察了这些选择中的2种:直接数据库调试(Direct Database Debugging)以及应用程序调试.要直接对一个T-SQL数据库对象进行调试的话,在服务器资源管理器里找到该对象,再右键单击选“Step Into …”. 这将打开调试器,且运行到该对象的第一条statement就终止了.此时,你可以进入该对象的statements,查看并修改参数值.在第一步,我们用该方法对Products_SelectByCategoryID存储过程进行了设置.