SLQ SERVER 2005调试方法 包括T-SQL文、存储过程和触发器

注:本文所讲的调试方法是针对SQL SERVER 2005。

  一 T-SQL调试

  有两种:一是在SQLSERVER MANAGE STUDIO(简称SSMS,或者叫MS SQL客户端)中使用print来查看结果;二是在VS2005或VS2008中调试,这种调试办法见下文。

  在SSMS中调试办法示例:

  新建查询过程,然后输入:

declare @a nvarchar(100)
  select @a = user_name from tb_user where user_id = 5
  print @a

 

  二 存储过程和触发器调试

  SQL SERVER 2000是可以在SSMS中单步调试的,但 SQL SERVER 2005 将这一功能从MS SQL 客户端工具SSMS中移除到了VS(VS2005版本以上的应该都具备存储过程调试功能,如果不具备,需要打补丁)中,废话少说,一下举例说明使用VS调试SQL SERVER 2005存储过程的方法:


  打开VS2005,选择工具、再选择“连接到数据库”。选择正确的数据库名和表名,填入正确的登陆信息就可以了,如图:




sql server没有调试按钮 sql调试器_数据库


  在"服务器资源管理“就可以看到写在数据库中的存储过程和触发器代码了,右击相应的存储过程,便可以看见”单步执行调试“的

字样如图所示:如果这段存储过程可以触发”触发器“中代码,那么触发器的代码也是可以调试的。


sql server没有调试按钮 sql调试器_存储过程_02


  我来举个例子调试一下。
  1、在数据中建立一个表AllMoney
  列 ID   类型 INT ,该字段为自增字段,每插入一条数据就增加一个。
  列 MyMoney 类型 Money

  2、在数据中建立一个表LastID
  列 ALLMoneyID 类型为INT,该字段将通过触发起自动更新值,当表AllMoney每插入一列的时候,这个字段就自动更新为AllMoney中的最大ID值。

  3、建立存储过程给AllMoney添加数据:

SET ANSI_NULLS ON
  GO
  SET QUOTED_IDENTIFIER ON
  GO
  CREATE PROCEDURE SP_InsertMoney
      @MyMoney AS MONEY
  AS
  BEGIN
      SET NOCOUNT ON;
      INSERT INTO AllMoney(MyMoney) VALUES(@MyMoney)
  END
  GO

  4、在表AllMoney中建立触发器,更新表LastID
  SET ANSI_NULLS ON
  GO
  SET QUOTED_IDENTIFIER ON
  GO
  CREATE TRIGGER INSERT_LastID
     ON AllMoney
     AFTER INSERT
  AS 
  BEGIN
      SET NOCOUNT ON
      DECLARE @ID AS INT
      SELECT @ID = MAX(ID) FROM AllMoney 
      UPDATE LastID SET AllMoneyID=@ID
  END
  GO



  当上面两个添加好后,然后再VS中来调试。


sql server没有调试按钮 sql调试器_sql server没有调试按钮_03


  首先打开触发器代码。并设置断点(也可以不打,调试将从起始处开始):


sql server没有调试按钮 sql调试器_触发器_04


  然后选择存储过程,点击右键选择单步调试存储过程。
  在弹出的对话框填入正确的参数:


sql server没有调试按钮 sql调试器_SQL_05


  这是就可以按F10进行过程调试,或者按F11进行单步调试来进行调试了,当数据插入成功后,就会触发”触发器“代码,前面我们在

触发器中设置断点就会断下来了,如图:


sql server没有调试按钮 sql调试器_SQL_06


  还可以看见变量的值,或者将鼠标悬浮于变量上,也可以看到变量值。