游戏技术文章

SQL 2005 的存储过程和触发器调试大法

时间:2016-11-3 12:30:36  作者:棋牌资源网  来源:棋牌资源网  查看:10101  评论:0
内容摘要:  昨天晚上我找遍了互联网也没有发现关于SQL2005存储过程和触发器的调试方法,研究到凌晨2点多钟,终于找到方法了,不干独享,拿出来分享。如果要转载,请保留版权,谢谢!       在SQL2000中,我们想...
  昨天晚上我找遍了互联网也没有发现关于SQL2005存储过程和触发器的调试方法,研究到凌晨2点多钟,终于找到方法了,不干独享,拿出来分享。如果要转载,请保留版权,谢谢!
       在SQL2000中,我们想要调试存储过程非常简单,只需要在对象浏览器中找到存储过程,然后点击鼠标右键选择“执行(调试)”就可以弹出一个工具栏出来,进行调试。然而到了SQL2005中同样的操作却变成了生成一段SQL语法,没有调试功能,如果使用了Express版本会更加郁闷,连“执行”菜单都没有,如图所示:Express版本中,菜单中根本没有“执行”功能。

SQL_2005_的存储过程和触发器调试大法

那么调试功能到什么地方去了呢?
别急,我找到了。原来微软把调试功能放在了VS2005中了。注意是VS2005,不是SQL2005,打开VS2005,选择工具、再选择“连接到数据库”。选择正确的数据库名和表名,填入正确的登陆信息就可以了,如图:

SQL_2005_的存储过程和触发器调试大法

在"服务器资源管理“就可以看到写在数据库中的存储过程和触发器代码了,右击相应的存储过程,便可以看见”单步执行调试“的字样如图所示:如果这段存储过程可以触发”触发器“中代码,那么触发器的代码也是可以调试的。

SQL_2005_的存储过程和触发器调试大法

我来举个例子调试一下。
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_2005_的存储过程和触发器调试大法

首先打开触发器代码。并设置断点:

SQL_2005_的存储过程和触发器调试大法

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

SQL_2005_的存储过程和触发器调试大法

这是就可以按F10来进行调试了,当数据插入成功后,就会触发”触发器“代码,前面我们在触发器中设置断点就会断下来了,如图:

SQL_2005_的存储过程和触发器调试大法

还可以看见变量的值,很不错吧!
标签:sql2005存储调试器 sql2005触发器调试方法 

欢迎加入VIP,【VIP售价:只要288元永久VIP会员】畅享商业棋牌游戏程序下载,点击开通!

下载说明


☉本站所有源码和资源均由站长亲自测试-绝对保证都可以架设,运营!
☉如源码和资源有损坏或所有链接均不能下载,请告知管理员,

☉本站软件和源码大部分为站长独资,资源购买和收集,放心下载!

☉唯一站长QQ:1004003180  [人格担保-本站注重诚信!]

☉购买建议E-mail:1004003180@qq.com   源码收购 E-mail:1004003180@qq.com    

☉本站文件解压密码  【文章内都自带解压密码,每个密码不同!】


本站提供的所有源码,均来源站长提供,仅学习交流 浙ICP备09009969号

由此产生不良后果和法律责任与本站无关,如果侵犯了您的版权,请来信告知 1004003180@qq.com 将及时更正和删除! 

Copyright © 2008-2024 棋牌资源网,你身边的棋牌资源下载站    All Rights Reserved