此页面上的内容需要较新版本的 Adobe Flash Player。

获取 Adobe Flash Player

您现在的位置: 智可网 - 程序开发 - 微软开发专区 - Visual Studio - 正文
Visual Studio中的SQL Server CLR代码调试(1)
教程录入:欧敏婷    责任编辑:gdzqgn 作者:佚名 文章来源:51CTO.COM

在Visual Studio中开发SQL Server CLR代码的好处在于,可以充分利用调试方面的工具。我们在开发普通的.Net代码时,对采用Visual Studio中的调试器进行单步调试已经是轻车熟路;在编写SQL Server的CLR代码时,又如何使用Visual Studio进行调试呢?接下来本文将介绍三种调试的方法。

为了更好地进行SQL Server CLR代码的调试,您需要使用Visual Studio专业或团队版。下表列出了可以使用调试器的Visual Studio的版本及开发语言,如图1所示:


图1:可使用调试器的Visual Studio的版本及开发语言

除了正确的Visual Studio版本和可支持的语言之外,还需要确保SQL Server中已经启用了“CLR集成”。可以在SQL Server外围应用配置器中进行设置。

需要特别注意的是:CLR调试时将导致其他所有线程停止,因此决不能在生产服务器尝试调试CLR。

一旦在Visual Studio的“服务器资源管理器”中的数据连接(如图2所示)设置了允许调试,那么在Visual Studio的“查看”菜单项中就多了项“服务器资源管理器”。


图2:服务器管理器中的数据连接启用CLR调试

当选择了“允许SQL/CLR调试”时,会看到如下所示的消息提示窗口:


图3:启用CLR调试时的消息提示窗口

一旦SQL Server中启用了CLR,并且连接项中启用了调试后,就可以开始调试过程。调试CLR代码的方法有三种:

1.使用服务器资源管理器,单步执行SQL Server 2005数据库对象;

2.使用Visual Studio 2005中的SQL Server项目,运行其中的测试脚本;

3.运行一个应用程序来调用存储过程。

方法1:单步执行一个对象

如果CLR代码已经部署到SQL Server上,我们就可以浏览CLR函数或存储过程,右键点击要调试的对象,在弹出菜单中选择“单步执行函数”或“单步执行存储过程”,如图4所示:


图4:单步执行函数

此操作将执行该函数或存储过程,将弹出一个窗口,我们可以输入参数的值,如图5所示:


图5:指定函数输入参数

指定完输入值,按“OK”按键后,就开始了调试过程。首先它将停在函数代码的起始位置,不论我们是否使用断点,如图6所示:


图6:调试停在函数开始位置

这时可以使用如图7所示的调试控制工具栏的功能按钮,逐行单步执行代码。


图7:调试控制工具栏

在本地窗口我们可以看到变量值变化的情况,如图8所示。此外,我们还可以利用其他调试功能。


图8:本地窗口中可以看到变量值变化情况

分享
打赏我
打开支付宝"扫一扫" 打开微信"扫一扫"
客户端
"扫一扫"下载智可网App
意见反馈
Visual Studio中的SQL Server CLR代码调试(1)
作者:佚名 来源:51CTO.COM

在Visual Studio中开发SQL Server CLR代码的好处在于,可以充分利用调试方面的工具。我们在开发普通的.Net代码时,对采用Visual Studio中的调试器进行单步调试已经是轻车熟路;在编写SQL Server的CLR代码时,又如何使用Visual Studio进行调试呢?接下来本文将介绍三种调试的方法。

为了更好地进行SQL Server CLR代码的调试,您需要使用Visual Studio专业或团队版。下表列出了可以使用调试器的Visual Studio的版本及开发语言,如图1所示:


图1:可使用调试器的Visual Studio的版本及开发语言

除了正确的Visual Studio版本和可支持的语言之外,还需要确保SQL Server中已经启用了“CLR集成”。可以在SQL Server外围应用配置器中进行设置。

需要特别注意的是:CLR调试时将导致其他所有线程停止,因此决不能在生产服务器尝试调试CLR。

一旦在Visual Studio的“服务器资源管理器”中的数据连接(如图2所示)设置了允许调试,那么在Visual Studio的“查看”菜单项中就多了项“服务器资源管理器”。


图2:服务器管理器中的数据连接启用CLR调试

当选择了“允许SQL/CLR调试”时,会看到如下所示的消息提示窗口:


图3:启用CLR调试时的消息提示窗口

一旦SQL Server中启用了CLR,并且连接项中启用了调试后,就可以开始调试过程。调试CLR代码的方法有三种:

1.使用服务器资源管理器,单步执行SQL Server 2005数据库对象;

2.使用Visual Studio 2005中的SQL Server项目,运行其中的测试脚本;

3.运行一个应用程序来调用存储过程。

方法1:单步执行一个对象

如果CLR代码已经部署到SQL Server上,我们就可以浏览CLR函数或存储过程,右键点击要调试的对象,在弹出菜单中选择“单步执行函数”或“单步执行存储过程”,如图4所示:


图4:单步执行函数

此操作将执行该函数或存储过程,将弹出一个窗口,我们可以输入参数的值,如图5所示:


图5:指定函数输入参数

指定完输入值,按“OK”按键后,就开始了调试过程。首先它将停在函数代码的起始位置,不论我们是否使用断点,如图6所示:


图6:调试停在函数开始位置

这时可以使用如图7所示的调试控制工具栏的功能按钮,逐行单步执行代码。


图7:调试控制工具栏

在本地窗口我们可以看到变量值变化的情况,如图8所示。此外,我们还可以利用其他调试功能。


图8:本地窗口中可以看到变量值变化情况