SQL存储过程调试

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

SQL存储过程调试
今天突然有同事问起,如何在sqlserver中调试存储过程(我们公司使⽤的是sqlserver 2008 R2),猛地⼀看,和以前使⽤sqlserver 2000真的有很⼤的不同,我真晕了。

于是琢磨了⼀下。

SQLSERVER 2005中不知因何去掉了很重要的DEBUGGER功能,要调试,必须要安装VS2005专业版或者更⾼版本。

⾮常不⽅便。

还好,SQLSERVER 2008中这个很重要⽽且⽅便的功能⼜回来了。

不过,SQLSERVER 2008的调试功能和SQL2000的⽅法差别很⼤。

SQL2000是在查询分析器中的对象浏览器中选中需要调试的存储过程,右键----调试---输⼊参数开始调试。

sqlserver2008中则完全不同,变成了必须要在SSMS中EXEC [PROCEDURE NAME] @VAR1,@VAR2,然后点绿⾊三⾓或者点菜单中的调试---启动调试。

然后点⼯具栏的最右边的单步调试或者跳出等。

下⾯的变量窗⼝和堆栈窗⼝等可以查看调试中变量等动态变化值。

sqlserver2008调试的要求和条件:如果在引擎所在的电脑或服务器上调试,则只需要SA或者WINDOWS⽤户登陆即可。

如果是异地调试,则需要设置防⽕墙例外,增加SSMS和SQLSERVER.EXE为允许,增加135端⼝允许通过。

总之,SQL2008的调试⽐2000操作起来⿇烦多了,要求也多了。

刚开始感觉不如2000的好⽤,也可能是使⽤2000习惯了。

习惯是可怕的,但是微软是在不断进步的...
⼀、回顾早期的SQL SERVER版本:
早在SQL Server 2000时代,查询分析器的功能还很简陋,远不如VS那么强⼤。

到SQL Server 2005时代,代码⾼亮、SQL优化等功能逐渐加强,但是依然⽆法调试SQL语句。

好⼀点的第三⽅的SQL语法编辑器似乎也不够完美,这样导致⼀些⼈抱怨存储过程不便于维护,开发的时候能不⽤则不⽤。

⼆、SQL Server 2008 Express 智能提⽰加强:
该功能是SQL2008在SQL Server 2005之后的升级版,我们可以很⽅便的调⽤智能提⽰,和 VS⼀致:使⽤快捷键ctrl + J 即可。

截图如下:
该功能是否与VS⼀样了呢?毕竟他们都是微软的产品。

三、调试T-SQL语句:
1.Debug普通T-SQL语句:
SQL代码如下:
1. use northwind
2. go
3. declare @i int ,@j int,@k int
4. set @i = 1;
5. set @j = 2;
6. set @k=@i + @j
7. select @i;
8. go
⾮常简单的定义了三个int 型变量:i、j、k并且对这些变量进⾏简单的逻辑运算,在Management Studio 中只要轻松的按F11键,即可调试以上代码块。

截图如下:
接着点击F11逐语句debug 或者F10逐过程调试代码。

截图如下:
这个dubug的场⾯您是否觉得已经和VS相差⽆⼏了呢?
四、⽀持复杂存储过程嵌套debug:
您可能会疑问,在⼀个庞⼤的系统中,如果数据库逻辑绝⼤部分都是存储过程实现的情况下,会出现存储过程嵌套存储过程或者嵌套存储函数这样的代码。

SQL2008是否⽀持调试功能呢?答案是肯定的。

⾸先定义⼀个简单的存储过程(本⽂使⽤NorthWind数据库)代码如下:
1. CREATE procedure sp_getOrders
2. @orderID int = null
3. as
4. if (@orderID is null )
5. begin
6. print 'null'
7. end
8. else
9. begin
10. print 'correct'
11. end
12. select * from Orders whereOrderID = @orderID
13. go
该存储过程在以下批处理内被调⽤,代码如下:
1. declare @i int ,@j int,@k int
2. set @i = 1;
3. set @j = 2;
4. select @k=@i + @j
5. exec sp_getOrders 10248
6. select @i;
7. go
F11对以上代码进⾏SQL Debug。

截图如下:
当断点经过exec sp_getOrders 10248 这段代码时,点击F11进⼊sp_getOrders存储过程进⾏逐语句debug。

截图如下:
这样可以在嵌套的存储过程或函数内进⾏debug了,此刻不得不承认: 升级后的SQL2008越来越强⼤。

您还恐惧使⽤或者调试存储过程么?原⽂来⾃。

相关文档
最新文档