分析数据库的依赖关系(转)

分析数据库的依赖关系(转)[@more@]

  有一个非常好的系统存储过程会帮助你分析数据库的依赖关系,它就是:sp_depends。这个过程会指出哪些数据库对象依赖于对应的数据库对象,和哪些数据库对象为对应的数据库对象引用了。

  

  

   如果所有的对象按依赖顺序创建的,那么这个系统存储过程会更鲁棒。那些依赖于其他对象的对象总是在它们引用的对象之后创建的。

  

   使用这个过程的一个原因是为了确定一个过程或者表的变化的影响。如果你有一个对象,它引用了30个对象,那么很有可能在编码期间,你为了改变这30个对象而须做更多的工作。

  

   下面的脚本展示一个存储过程和一些对象,这个存储过程引用了一些对象,其他对象又引用了这个存储过程。

  

  IF EXISTS(SELECT name

   FROM sysobjects

   WHERE name = N'test_table'

   AND type = 'U')

   DROP TABLE test_table

  GO

  CREATE TABLE test_table (

  c1 VARCHAR(255) NULL)

  GO

  IF EXISTS (SELECT name

   FROM sysobjects

   WHERE name = N'test_proc1'

   AND type = 'P')

   DROP PROCEDURE test_proc1

  GO

  CREATE PROCEDURE test_proc1 @name sysname = NULL

  AS

  IF @name IS NOT NULL

  BEGIN

   INSERT test_table VALUES (@name)

  END

  ELSE

  BEGIN

   RETURN

  END

  GO

  IF EXISTS (SELECT name

   FROM sysobjects

   WHERE name = N'test_proc2'

   AND type = 'P')

   DROP PROCEDURE test_proc2

  GO

  CREATE PROCEDURE test_proc2

  AS

  DECLARE @myVar sysname

  SELECT @myVar = name FROM sysobjects WHERE id = 1

  EXEC test_proc1 @myVar

  GO

  EXEC sp_depends test_proc1

  GO

  DROP PROCEDURE test_proc2, test_proc1

  GO

  DROP TABLE test_table

  GO


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8225414/viewspace-956773/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/8225414/viewspace-956773/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值