Visual Studio中SQL SERVER CLR代码调试工具使用讲解
创始人
2024-06-09 10:31:27
0

做开发的人都知道代码调试是最痛苦的一件事情,有时一个小小的错误就会让我们花费上一天的时间,在Visual Studio有SQL Server CLR代码调试的功能可以让我们自己省去调试的时间,让我们快来看看吧。

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

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

可使用SQL SERVER CLR代码调试器的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,并且连接项中启用了调试后,就可以开始调试过程。SQL SERVER CLR代码调试的方法有三种:
1.使用服务器资源管理器,单步执行SQL Server 2005数据库对象;
2.使用Visual Studio 2005中的SQL Server项目,运行其中的测试脚本;
3.运行一个应用程序来调用存储过程。

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

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

单步执行函数

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

指定函数输入参数

 

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

调试停在函数开始位置

 

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

[[6447]]498)this.style.width=498;" border=0>

 

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

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

【编辑推荐】

  1. CLR触发器实战演练
  2. 浅析如何调试SQL CLR存储过程
  3. 浅析CLR类库调用方法
  4. .NET CLR性能评测
  5. 浅谈.NET CLR的基础知识

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...