存储过程调试

存储过程调试

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

昨天被问到sql server中存储过程怎么调试,我曾经写存储过程,调试方法非常笨拙,就是逐条运行语句,然后查看结果是不是预期的,这样的调试方法,实在是无奈之举,极大程度地限制了开发速度和准确性。今天在他的提点下,研究了下SQL SERVER 2008的存储过程调试。

1.在SQL SERVER2008中调试存储过程

下面内容引自MSDN

SQL SERVER 2008的SSMS是支持单步debug的,可是在调试之前必须配置权限。

假设 SQL Server Management Studio 与 SQL Server 数据库引擎实例在同一台计算机上执行,则对于执行 Transact-SQL 调试器没有配置要求。可是,当 SQL Server Management Studio 与数据库引擎实例在不同计算机上执行时,若要执行 Transact-SQL 调试器,则必须在两台计算机上使用“Windows 防火墙”控制面板应用程序来启用程序和port例外。

在执行数据库引擎实例的计算机上,在“Windows 防火墙”中指定下面信息:

  • 将 TCP port 135 加入�到例外列表。

  • 将程序 sqlservr.exe 加入�到例外列表。默认情况下,sqlservr.exe 安装在 C:\Program Files\Microsoft SQL Server\MSSQL10.实例名称\MSSQL\Binn 下,当中,实例名称对于默认实例为 MSSQLSERVER,对于不论什么指定的实例则为对应实例的名称。

  • 假设域策略要求通过 IPSec 进行网络通信,还必须将 UDP port 4500 和 UDP port 500 加入�到例外列表。

在执行 SQL Server Management Studio 的计算机上,在“Windows 防火墙”中指定下面信息:

  • 将 TCP port 135 加入�到例外列表。

  • 将程序 ssms.exe (SQL Server Management Studio) 加入�到例外列表。默认情况下,ssms.exe 安装在 C:\Program Files\Microsoft SQL Server\100\Tools\Binn\VSShell\Common7\IDE 下。

  • 启动 Transact-SQL 调试器的要求例如以下:

    • SQL Server Management Studio 必须在作为 sysadmin 固定server角色成员的 Windows 帐户下执行。

    • 数据库引擎查询编辑器窗体必须使用 Windows 身份验证来连接,或使用作为 sysadmin 固定server角色成员的 SQL Server 身份验证登录名来连接。

    • 数据库引擎查询编辑器窗体必须连接到 SQL Server 2008数据库引擎的实例。假设查询编辑器窗体连接到处于单用户模式下的实例,您将无法执行调试器。

    我们建议在測试server上调试 Transact-SQL 代码,而不要在生产server上调试,原因例如以下:

    • 调试是一项须要高特权的操作。因此仅仅同意 sysadmin 固定server角色成员在 SQL Server 中进行调试。

    • 当您调查多个 Transact-SQL 语句的执行时,调试会话一般会执行非常长时间。会话获取的锁(如更新锁)可能会持有非常长时间,直到终止会话或者提交或回滚事务。

    启动 Transact-SQL 调试器可将查询编辑器窗体置于调试模式。在查询编辑器窗体进入调试模式时,调试器会在第一个代码行处暂停。然后,您能够单步运行代码,在特定 Transact-SQL 语句上暂停运行,并使用调试器窗体来查看当前运行状态。能够通过在“查询”工具栏上单击“调试”button,或在“调试”菜单上单击“启动调试”来启动调试器。

    查询编辑器窗体会保持在调试模式下,直到查询编辑器窗体中的最后一个语句完毕或您停止调试模式。能够使用下面不论什么一种方法来停止调试模式和语句运行:

    • “调试”菜单中,单击“停止调试”

    • “调试”工具栏上,单击“停止调试”button。

    • “查询”菜单上,单击“取消运行查询”

    • “查询”工具栏上,单击“取消运行查询”button。

    也可在“调试”菜单上单击“所有分离”,以停止调试模式,但同意剩余的 Transact-SQL 语句完毕运行。

原文http://msdn.microsoft.com/zh-cn/library/cc646024(v=SQL.100).aspx

2.在Visual Studio中调试存储过程(以VS2010为例)

打开server资源管理器,加入�一个SQL SERVER 2008数据库连接,然后在存储过程节点上点右键,选择“单步运行存储过程”,就可以进入单步调试状态,同上边过程,也要设置权限。

   大家一定在编写或分析一个复杂存错过程时,非常希望能想VB代码一样进行调试,可惜SQL Server本身并没有提供调试器,我们能够利用VS来进行调试。

   我写了一个简单的存储过程,介绍一下用VS调试存储过程的步骤。

 

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
Create
PROCEDURE
testProcDebugger
    
@id
int
AS
BEGIN
    
declare
@testVal1
int
    
set
@testVal1=@id
    
declare
@empid
varchar
    
declare
@shipperid
varchar
  
    
select
@empid=shipperid,@shipperid=empid
from
orders
    
where
orderid=@testVal1
  
    
select
@empid,@shipperid
END

 

 

第一步:启动Visual Studio,点“试图”->“服务资源管理器”

存储过程调试

 

第二步:加入�数据连接。
    
填写好数据库名、登录账号、和要连接的数据库,点确定。
 
第三步:在要调试的存错过程上右键,选择“单步运行存储过程”
     
第四步:这时调试器会依据存储过程的參数,提示你输入几个用于条数的值,然后点确定就能够进入调试状态了。
      
如今大家就能够像调试VB代码一样,进行一步一步的跟踪了。

第二步:加入�数据连接。

存储过程调试

 

填写好数据库名、登录账号、和要连接的数据库,点确定。
 
第三步:在要调试的存错过程上右键,选择“单步运行存储过程”

存储过程调试

  
第四步:这时调试器会依据存储过程的參数,提示你输入几个用于条数的值,然后点确定就能够进入调试状态了。
存储过程调试

 
如今大家就能够像调试VB代码一样,进行一步一步的跟踪了。

存储过程调试

分类:
开发技能

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/118450.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 搭建Android开发环境(超详细)

    搭建Android开发环境(超详细)文章转自:http://www.cnblogs.com/xdp-gacl/p/4322165.html搭建最新版本的Android开发环境  最近由于工作中要负责开发一款Android的App,之前都是做JavaWeb的开发,Android开发虽然有所了解,但是一直没有搭建开发环境去学习,Android的更新速度比较快了,Android1.0是2008年发布的,截止到目前为止And

  • origin做上下柱状图_利用excel制作柱状图

    origin做上下柱状图_利用excel制作柱状图目标:在Origin8中作向下的柱状图(暂且这么称呼吧),类似下图形式:示例数据:方法1:最简便的方法——(1)将数据X、Y1生成条状图(“normal”);(2)菜单栏Window——ScriptWindow;(3)点击生成的Graph图层(激活状态);(4)在ScriptWindow输入layer1.y.r…

  • java构造函数返回值_java构造函数总结

    java构造函数返回值_java构造函数总结构造函数总结概念:创建对象时由JVM自动调用的函数作用:在创建对象的时候给对象的成员变量赋值;写法:修饰符:可以用访问权限修饰符(public、private等)修饰;不能用static修饰;返回值类型:没有返回值类型,连void都没有;函数名:必须和类名完全一样;参数列表:可以重载,具体根据要求而定;return语句:有,但是一般都不需要写;执行过程:创建对象时,JVM遇到new…

  • OHEM算法及Caffe代码详解

    OHEM算法及Caffe代码详解这是CVPR2016的一篇论文,用于目标检测,本篇博文先介绍这个算法,然后介绍其Caffe代码。论文:TrainingRegion-basedObjectDetectorswithOnlineHardExampleMining论文链接:https://arxiv.org/abs/1604.03540算法概述:OHEM(onlinehardexampleminiing)算法的

  • OpenCV繪圖的實作-cvCircle,cvEllipse,cvEllipseBox

    OpenCV繪圖的實作-cvCircle,cvEllipse,cvEllipseBox转自:http://www.90in.net/space-4-do-blog-id-10218.htmlOpenCV繪圖的實作-cvCircle,cvEllipse,cvEllipseBox圓的製作,要給他目標圖片,圓心座標,半徑,其他參數等.cvCircle()函式的實作#include<cv.h>#include<highgui.h>IplImag…

  • 手机点餐系统概述_实训答辩安卓点餐系统ppt课件「建议收藏」

    手机点餐系统概述_实训答辩安卓点餐系统ppt课件「建议收藏」《实训答辩安卓点餐系统ppt课件》由会员分享,可在线阅读,更多相关《实训答辩安卓点餐系统ppt课件(13页珍藏版)》请在人人文库网上搜索。1、quiky,diet,Contents,背景,设计思想,产品优势,产品概述,功能介绍,伴随着我国市场经济的高度发展,企业越来越依赖于市场和客户,而如今的餐饮业大都以实际门面形式来进行宣传和交流,作为网络普及化的社会,它还缺少了许多更为现代化的元素,餐饮业是一…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号